summaryrefslogtreecommitdiffstats
path: root/cmd-select-pane.c
diff options
context:
space:
mode:
authornicm <nicm>2015-09-14 11:34:50 +0000
committernicm <nicm>2015-09-14 11:34:50 +0000
commitaf16ce6ad9170e6a48e79e3af696f60daa2bae1d (patch)
tree740fb5b23280446e3143d2084362f01128474115 /cmd-select-pane.c
parent16efa8483888e326aed2c05a01b63b45a2b118ef (diff)
When the active pane changes, redraw panes if the style has
changed. From Cam Hutchison.
Diffstat (limited to 'cmd-select-pane.c')
-rw-r--r--cmd-select-pane.c28
1 files changed, 17 insertions, 11 deletions
diff --git a/cmd-select-pane.c b/cmd-select-pane.c
index 5ea4bdc3..e76587cc 100644
--- a/cmd-select-pane.c
+++ b/cmd-select-pane.c
@@ -47,6 +47,7 @@ cmd_select_pane_exec(struct cmd *self, struct cmd_q *cmdq)
{
struct args *args = self->args;
struct winlink *wl;
+ struct window *w;
struct session *s;
struct window_pane *wp, *lastwp, *markedwp;
const char *style;
@@ -55,21 +56,24 @@ cmd_select_pane_exec(struct cmd *self, struct cmd_q *cmdq)
wl = cmd_find_window(cmdq, args_get(args, 't'), NULL);
if (wl == NULL)
return (CMD_RETURN_ERROR);
+ w = wl->window;
- if (wl->window->last == NULL) {
+ if (w->last == NULL) {
cmdq_error(cmdq, "no last pane");
return (CMD_RETURN_ERROR);
}
if (args_has(self->args, 'e'))
- wl->window->last->flags &= ~PANE_INPUTOFF;
+ w->last->flags &= ~PANE_INPUTOFF;
else if (args_has(self->args, 'd'))
- wl->window->last->flags |= PANE_INPUTOFF;
+ w->last->flags |= PANE_INPUTOFF;
else {
- server_unzoom_window(wl->window);
- window_set_active_pane(wl->window, wl->window->last);
- server_status_window(wl->window);
- server_redraw_window_borders(wl->window);
+ server_unzoom_window(w);
+ window_redraw_active_switch(w, w->last);
+ if (window_set_active_pane(w, w->last)) {
+ server_status_window(w);
+ server_redraw_window_borders(w);
+ }
}
return (CMD_RETURN_NORMAL);
@@ -77,6 +81,7 @@ cmd_select_pane_exec(struct cmd *self, struct cmd_q *cmdq)
if ((wl = cmd_find_pane(cmdq, args_get(args, 't'), &s, &wp)) == NULL)
return (CMD_RETURN_ERROR);
+ w = wl->window;
if (args_has(args, 'm') || args_has(args, 'M')) {
if (args_has(args, 'm') && !window_pane_visible(wp))
@@ -135,16 +140,17 @@ cmd_select_pane_exec(struct cmd *self, struct cmd_q *cmdq)
return (CMD_RETURN_NORMAL);
}
- if (wp == wl->window->active)
+ if (wp == w->active)
return (CMD_RETURN_NORMAL);
server_unzoom_window(wp->window);
if (!window_pane_visible(wp)) {
cmdq_error(cmdq, "pane not visible");
return (CMD_RETURN_ERROR);
}
- if (window_set_active_pane(wl->window, wp)) {
- server_status_window(wl->window);
- server_redraw_window_borders(wl->window);
+ window_redraw_active_switch(w, wp);
+ if (window_set_active_pane(w, wp)) {
+ server_status_window(w);
+ server_redraw_window_borders(w);
}
return (CMD_RETURN_NORMAL);