aboutsummaryrefslogtreecommitdiff
path: root/cmd-select-pane.c
diff options
context:
space:
mode:
authorThomas Adam <thomas@xteddy.org>2015-04-27 21:21:55 +0100
committerThomas Adam <thomas@xteddy.org>2015-04-27 21:21:55 +0100
commit94a8ef1caef855d1a43b6373dd08ce0bbf4aadd5 (patch)
tree052d89cf9193a324fb646fe25152df6aa4070534 /cmd-select-pane.c
parent72e9ebf2ece28c986050162bf4f401a6a7679f53 (diff)
parent95195f52584565483bf9850840f6d81cd88bf9b2 (diff)
downloadrtmux-94a8ef1caef855d1a43b6373dd08ce0bbf4aadd5.tar.gz
rtmux-94a8ef1caef855d1a43b6373dd08ce0bbf4aadd5.tar.bz2
rtmux-94a8ef1caef855d1a43b6373dd08ce0bbf4aadd5.zip
Merge branch 'obsd-master'
Conflicts: Makefile tmux.1
Diffstat (limited to 'cmd-select-pane.c')
-rw-r--r--cmd-select-pane.c24
1 files changed, 15 insertions, 9 deletions
diff --git a/cmd-select-pane.c b/cmd-select-pane.c
index c84b4149..e7f2249e 100644
--- a/cmd-select-pane.c
+++ b/cmd-select-pane.c
@@ -77,12 +77,6 @@ cmd_select_pane_exec(struct cmd *self, struct cmd_q *cmdq)
if ((wl = cmd_find_pane(cmdq, args_get(args, 't'), NULL, &wp)) == NULL)
return (CMD_RETURN_ERROR);
- server_unzoom_window(wp->window);
- if (!window_pane_visible(wp)) {
- cmdq_error(cmdq, "pane not visible");
- return (CMD_RETURN_ERROR);
- }
-
if (args_has(self->args, 'P') || args_has(self->args, 'g')) {
if (args_has(args, 'P')) {
style = args_get(args, 'P');
@@ -111,11 +105,23 @@ cmd_select_pane_exec(struct cmd *self, struct cmd_q *cmdq)
return (CMD_RETURN_ERROR);
}
- if (args_has(self->args, 'e'))
+ if (args_has(self->args, 'e')) {
wp->flags &= ~PANE_INPUTOFF;
- else if (args_has(self->args, 'd'))
+ return (CMD_RETURN_NORMAL);
+ }
+ if (args_has(self->args, 'd')) {
wp->flags |= PANE_INPUTOFF;
- else if (window_set_active_pane(wl->window, wp)) {
+ return (CMD_RETURN_NORMAL);
+ }
+
+ if (wp == wl->window->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);
}