Merge branch 'obsd-master'

This commit is contained in:
Thomas Adam 2016-09-28 10:01:11 +01:00
commit 27591570c4
3 changed files with 41 additions and 4 deletions

View File

@ -763,11 +763,13 @@ server_client_loop(void)
} }
} }
/* Check if pane should be resized. */ static void
void server_client_resize_event(__unused int fd, __unused short events, void *data)
server_client_check_resize(struct window_pane *wp)
{ {
struct winsize ws; struct window_pane *wp = data;
struct winsize ws;
evtimer_del(&wp->resize_timer);
if (!(wp->flags & PANE_RESIZE)) if (!(wp->flags & PANE_RESIZE))
return; return;
@ -792,6 +794,36 @@ server_client_check_resize(struct window_pane *wp)
wp->flags &= ~PANE_RESIZE; 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. */ /* Check whether pane should be focused. */
void void
server_client_check_focus(struct window_pane *wp) server_client_check_focus(struct window_pane *wp)

2
tmux.h
View File

@ -896,6 +896,8 @@ struct window_pane {
int fd; int fd;
struct bufferevent *event; struct bufferevent *event;
struct event resize_timer;
u_int wmark_size; u_int wmark_size;
u_int wmark_hits; u_int wmark_hits;

View File

@ -806,6 +806,9 @@ window_pane_destroy(struct window_pane *wp)
close(wp->pipe_fd); close(wp->pipe_fd);
} }
if (event_initialized(&wp->resize_timer))
event_del(&wp->resize_timer);
RB_REMOVE(window_pane_tree, &all_window_panes, wp); RB_REMOVE(window_pane_tree, &all_window_panes, wp);
free((void *)wp->cwd); free((void *)wp->cwd);