diff options
author | nicm <nicm> | 2014-10-21 22:22:04 +0000 |
---|---|---|
committer | nicm <nicm> | 2014-10-21 22:22:04 +0000 |
commit | a02c2e55c0ee0a6f2d3a897c06a396794b765a6c (patch) | |
tree | 3ca0f7fa5f46024a10c3f2f1c5a92448bc2f0828 | |
parent | 85671a5bed961b7a542ffce853749fb61b0558ca (diff) | |
download | rtmux-a02c2e55c0ee0a6f2d3a897c06a396794b765a6c.tar.gz rtmux-a02c2e55c0ee0a6f2d3a897c06a396794b765a6c.tar.bz2 rtmux-a02c2e55c0ee0a6f2d3a897c06a396794b765a6c.zip |
Only redraw pane when it has actually changed.
-rw-r--r-- | cmd-select-pane.c | 3 | ||||
-rw-r--r-- | tmux.h | 2 | ||||
-rw-r--r-- | window.c | 7 |
3 files changed, 6 insertions, 6 deletions
diff --git a/cmd-select-pane.c b/cmd-select-pane.c index 99594ae9..5810eeab 100644 --- a/cmd-select-pane.c +++ b/cmd-select-pane.c @@ -99,8 +99,7 @@ cmd_select_pane_exec(struct cmd *self, struct cmd_q *cmdq) wp->flags &= ~PANE_INPUTOFF; else if (args_has(self->args, 'd')) wp->flags |= PANE_INPUTOFF; - else { - window_set_active_pane(wl->window, wp); + else if (window_set_active_pane(wl->window, wp)) { server_status_window(wl->window); server_redraw_window_borders(wl->window); } @@ -2116,7 +2116,7 @@ void window_destroy(struct window *); struct window_pane *window_get_active_at(struct window *, u_int, u_int); void window_set_active_at(struct window *, u_int, u_int); struct window_pane *window_find_string(struct window *, const char *); -void window_set_active_pane(struct window *, struct window_pane *); +int window_set_active_pane(struct window *, struct window_pane *); struct window_pane *window_add_pane(struct window *, u_int); void window_resize(struct window *, u_int, u_int); int window_zoom(struct window_pane *); @@ -386,11 +386,11 @@ window_resize(struct window *w, u_int sx, u_int sy) w->sy = sy; } -void +int window_set_active_pane(struct window *w, struct window_pane *wp) { if (wp == w->active) - return; + return (0); w->last = w->active; w->active = wp; while (!window_pane_visible(w->active)) { @@ -398,9 +398,10 @@ window_set_active_pane(struct window *w, struct window_pane *wp) if (w->active == NULL) w->active = TAILQ_LAST(&w->panes, window_panes); if (w->active == wp) - return; + return (1); } w->active->active_point = next_active_point++; + return (1); } struct window_pane * |