diff options
Diffstat (limited to 'usr.bin/tmux')
-rw-r--r-- | usr.bin/tmux/tty.c | 63 |
1 files changed, 6 insertions, 57 deletions
diff --git a/usr.bin/tmux/tty.c b/usr.bin/tmux/tty.c index cdb5b074fb1..964275d00a4 100644 --- a/usr.bin/tmux/tty.c +++ b/usr.bin/tmux/tty.c @@ -1,4 +1,4 @@ -/* $OpenBSD: tty.c,v 1.245 2017/02/10 15:38:23 nicm Exp $ */ +/* $OpenBSD: tty.c,v 1.246 2017/02/10 15:39:14 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott <nicholas.marriott@gmail.com> @@ -171,59 +171,18 @@ tty_read_callback(__unused int fd, __unused short events, void *data) } static void -tty_timer_callback(__unused int fd, __unused short events, void *data) -{ - struct tty *tty = data; - struct client *c = tty->client; - const struct timeval tv = { .tv_usec = 250000 }; - - server_client_add_message(c, "%s: %zu discarded", tty->path, - tty->discarded); - - c->flags |= CLIENT_REDRAW; - - if (tty->discarded < 256) { - tty->flags &= ~TTY_BLOCK; - tty_invalidate(tty); - return; - } - tty->discarded = 0; - evtimer_add(&tty->timer, &tv); -} - -static void tty_write_callback(__unused int fd, __unused short events, void *data) { - struct tty *tty = data; - struct client *c = tty->client; - size_t size = EVBUFFER_LENGTH(tty->out), left; - int nwrite; - const struct timeval tv = { .tv_usec = 250000 }; + struct tty *tty = data; + size_t size = EVBUFFER_LENGTH(tty->out); + int nwrite; nwrite = evbuffer_write(tty->out, tty->fd); if (nwrite == -1) return; log_debug("%s: wrote %d bytes (of %zu)", tty->path, nwrite, size); - /* - * If we aren't managing to write everything (so we are creating more - * data than the terminal can accept), then the terminal can't keep up. - */ - left = EVBUFFER_LENGTH(tty->out); - if (left > 32768 && nwrite < (int)size && (~tty->flags & TTY_BLOCK)) { - server_client_add_message(c, "%s: can't keep up, %zu discarded", - tty->path, left); - - evbuffer_drain(tty->out, left); - event_del(&tty->event_out); - - tty->discarded = 0; - evtimer_add(&tty->timer, &tv); - - tty->flags |= TTY_BLOCK; - return; - } - if (left == 0) + if (EVBUFFER_LENGTH(tty->out) == 0) event_del(&tty->event_out); } @@ -237,7 +196,7 @@ tty_open(struct tty *tty, char **cause) } tty->flags |= TTY_OPENED; - tty->flags &= ~(TTY_NOCURSOR|TTY_FREEZE|TTY_BLOCK|TTY_TIMER); + tty->flags &= ~(TTY_NOCURSOR|TTY_FREEZE); event_set(&tty->event_in, tty->fd, EV_PERSIST|EV_READ, tty_read_callback, tty); @@ -246,8 +205,6 @@ tty_open(struct tty *tty, char **cause) event_set(&tty->event_out, tty->fd, EV_WRITE, tty_write_callback, tty); tty->out = evbuffer_new(); - evtimer_set(&tty->timer, tty_timer_callback, tty); - tty_start_tty(tty); tty_keys_build(tty); @@ -314,9 +271,6 @@ tty_stop_tty(struct tty *tty) return; tty->flags &= ~TTY_STARTED; - event_del(&tty->timer); - tty->flags &= ~TTY_BLOCK; - event_del(&tty->event_in); event_del(&tty->event_out); @@ -468,11 +422,6 @@ tty_putcode_ptr2(struct tty *tty, enum tty_code_code code, const void *a, static void tty_add(struct tty *tty, const char *buf, size_t len) { - if ((tty->flags & TTY_BLOCK) && (~tty->flags & TTY_FORCE)) { - tty->discarded += len; - return; - } - evbuffer_add(tty->out, buf, len); log_debug("%s: %.*s", tty->path, (int)len, (const char *)buf); |