diff options
author | Thomas Adam <thomas@xteddy.org> | 2017-05-09 15:44:33 +0100 |
---|---|---|
committer | Thomas Adam <thomas@xteddy.org> | 2017-05-09 15:44:33 +0100 |
commit | 4bcb64f8c15e9e928ce8266f01edd2107feb8ef2 (patch) | |
tree | a38ac12807850603d223eba51b79d811b6fa8712 /tty.c | |
parent | a651b08a2f95bb206ae6385801518f93fdd5000e (diff) | |
parent | 3b35daacf734dc824b6101e54d62067fde6016b8 (diff) | |
download | rtmux-4bcb64f8c15e9e928ce8266f01edd2107feb8ef2.tar.gz rtmux-4bcb64f8c15e9e928ce8266f01edd2107feb8ef2.tar.bz2 rtmux-4bcb64f8c15e9e928ce8266f01edd2107feb8ef2.zip |
Merge branch 'obsd-master'
Diffstat (limited to 'tty.c')
-rw-r--r-- | tty.c | 11 |
1 files changed, 9 insertions, 2 deletions
@@ -233,7 +233,14 @@ tty_write_callback(__unused int fd, __unused short events, void *data) return; log_debug("%s: wrote %d bytes (of %zu)", c->name, nwrite, size); - if (tty_block_maybe(tty)) + if (c->redraw > 0) { + if ((size_t)nwrite >= c->redraw) + c->redraw = 0; + else + c->redraw -= nwrite; + log_debug("%s: waiting for redraw, %zu bytes left", c->name, + c->redraw); + } else if (tty_block_maybe(tty)) return; if (EVBUFFER_LENGTH(tty->out) != 0) @@ -488,7 +495,7 @@ tty_add(struct tty *tty, const char *buf, size_t len) } evbuffer_add(tty->out, buf, len); - log_debug("%s: %.*s", c->name, (int)len, (const char *)buf); + log_debug("%s: %.*s", c->name, (int)len, buf); c->written += len; if (tty_log_fd != -1) |