aboutsummaryrefslogtreecommitdiff
path: root/server-client.c
diff options
context:
space:
mode:
authorThomas Adam <thomas@xteddy.org>2016-09-28 10:01:11 +0100
committerThomas Adam <thomas@xteddy.org>2016-09-28 10:01:11 +0100
commit27591570c4a6d1142e0403e209106326a45b859e (patch)
tree13965ccc6fd62b1bfca736c8a3ff00664319df4a /server-client.c
parent30f2e8ff29b112b6b428d1d123187fdfd497e814 (diff)
parentacacb718e5452bfdba4810007d5a10eace1a9fec (diff)
downloadrtmux-27591570c4a6d1142e0403e209106326a45b859e.tar.gz
rtmux-27591570c4a6d1142e0403e209106326a45b859e.tar.bz2
rtmux-27591570c4a6d1142e0403e209106326a45b859e.zip
Merge branch 'obsd-master'
Diffstat (limited to 'server-client.c')
-rw-r--r--server-client.c40
1 files changed, 36 insertions, 4 deletions
diff --git a/server-client.c b/server-client.c
index f61cfa38..311b2d3b 100644
--- a/server-client.c
+++ b/server-client.c
@@ -763,11 +763,13 @@ server_client_loop(void)
}
}
-/* Check if pane should be resized. */
-void
-server_client_check_resize(struct window_pane *wp)
+static void
+server_client_resize_event(__unused int fd, __unused short events, void *data)
{
- struct winsize ws;
+ struct window_pane *wp = data;
+ struct winsize ws;
+
+ evtimer_del(&wp->resize_timer);
if (!(wp->flags & PANE_RESIZE))
return;
@@ -792,6 +794,36 @@ server_client_check_resize(struct window_pane *wp)
wp->flags &= ~PANE_RESIZE;
}
+/* Check if pane should be resized. */
+void
+server_client_check_resize(struct window_pane *wp)
+{
+ struct timeval tv = { .tv_usec = 250000 };
+
+ if (!(wp->flags & PANE_RESIZE))
+ return;
+
+ if (!event_initialized(&wp->resize_timer))
+ evtimer_set(&wp->resize_timer, server_client_resize_event, wp);
+
+ /*
+ * The first resize should happen immediately, so if the timer is not
+ * running, do it now.
+ */
+ if (!evtimer_pending(&wp->resize_timer, NULL))
+ server_client_resize_event(-1, 0, wp);
+
+ /*
+ * If the pane is in the alternate screen, let the timer expire and
+ * resize to give the application a chance to redraw. If not, keep
+ * pushing the timer back.
+ */
+ if (wp->saved_grid != NULL && evtimer_pending(&wp->resize_timer, NULL))
+ return;
+ evtimer_del(&wp->resize_timer);
+ evtimer_add(&wp->resize_timer, &tv);
+}
+
/* Check whether pane should be focused. */
void
server_client_check_focus(struct window_pane *wp)