mirror of
https://github.com/tmux/tmux.git
synced 2025-01-07 08:18:48 +00:00
Mouse bindings and hooks set up an initial current state when running a
command. This is used for the session, window and pane for all commands in the command sequence if there is no -t or -s. However, using it for all commands in the command sequence means that if the active pane or current session is changed, subsequent commands still use the previous state. So make commands which explicitly change the current state (such as neww and selectp) update it themselves for later commands. Commands which may invalidate the state (like killp) are already OK because an invalid state will be ignored. Also fill in the current state for all key bindings rather than just the mouse, so that any omissions are easier to spot.
This commit is contained in:
parent
bcab77e266
commit
2c0f826c36
@ -50,6 +50,7 @@ enum cmd_retval
|
|||||||
cmd_attach_session(struct cmdq_item *item, int dflag, int rflag,
|
cmd_attach_session(struct cmdq_item *item, int dflag, int rflag,
|
||||||
const char *cflag, int Eflag)
|
const char *cflag, int Eflag)
|
||||||
{
|
{
|
||||||
|
struct cmd_find_state *current = &item->shared->current;
|
||||||
struct session *s = item->state.tflag.s;
|
struct session *s = item->state.tflag.s;
|
||||||
struct client *c = item->client, *c_loop;
|
struct client *c = item->client, *c_loop;
|
||||||
struct winlink *wl = item->state.tflag.wl;
|
struct winlink *wl = item->state.tflag.wl;
|
||||||
@ -73,6 +74,10 @@ cmd_attach_session(struct cmdq_item *item, int dflag, int rflag,
|
|||||||
if (wp != NULL)
|
if (wp != NULL)
|
||||||
window_set_active_pane(wp->window, wp);
|
window_set_active_pane(wp->window, wp);
|
||||||
session_set_current(s, wl);
|
session_set_current(s, wl);
|
||||||
|
if (wp != NULL)
|
||||||
|
cmd_find_from_winlink_pane(current, wl, wp);
|
||||||
|
else
|
||||||
|
cmd_find_from_winlink(current, wl);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cflag != NULL) {
|
if (cflag != NULL) {
|
||||||
|
@ -48,6 +48,7 @@ static enum cmd_retval
|
|||||||
cmd_break_pane_exec(struct cmd *self, struct cmdq_item *item)
|
cmd_break_pane_exec(struct cmd *self, struct cmdq_item *item)
|
||||||
{
|
{
|
||||||
struct args *args = self->args;
|
struct args *args = self->args;
|
||||||
|
struct cmd_find_state *current = &item->shared->current;
|
||||||
struct client *c = item->state.c;
|
struct client *c = item->state.c;
|
||||||
struct winlink *wl = item->state.sflag.wl;
|
struct winlink *wl = item->state.sflag.wl;
|
||||||
struct session *src_s = item->state.sflag.s;
|
struct session *src_s = item->state.sflag.s;
|
||||||
@ -93,8 +94,10 @@ cmd_break_pane_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
if (idx == -1)
|
if (idx == -1)
|
||||||
idx = -1 - options_get_number(dst_s->options, "base-index");
|
idx = -1 - options_get_number(dst_s->options, "base-index");
|
||||||
wl = session_attach(dst_s, w, idx, &cause); /* can't fail */
|
wl = session_attach(dst_s, w, idx, &cause); /* can't fail */
|
||||||
if (!args_has(self->args, 'd'))
|
if (!args_has(self->args, 'd')) {
|
||||||
session_select(dst_s, wl->idx);
|
session_select(dst_s, wl->idx);
|
||||||
|
cmd_find_from_session(current, dst_s);
|
||||||
|
}
|
||||||
|
|
||||||
server_redraw_session(src_s);
|
server_redraw_session(src_s);
|
||||||
if (src_s != dst_s)
|
if (src_s != dst_s)
|
||||||
|
@ -142,6 +142,7 @@ static enum cmd_retval
|
|||||||
cmd_find_window_exec(struct cmd *self, struct cmdq_item *item)
|
cmd_find_window_exec(struct cmd *self, struct cmdq_item *item)
|
||||||
{
|
{
|
||||||
struct args *args = self->args;
|
struct args *args = self->args;
|
||||||
|
struct cmd_find_state *current = &item->shared->current;
|
||||||
struct client *c = item->state.c;
|
struct client *c = item->state.c;
|
||||||
struct window_choose_data *cdata;
|
struct window_choose_data *cdata;
|
||||||
struct session *s = item->state.tflag.s;
|
struct session *s = item->state.tflag.s;
|
||||||
@ -177,8 +178,10 @@ cmd_find_window_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (TAILQ_NEXT(TAILQ_FIRST(&find_list), entry) == NULL) {
|
if (TAILQ_NEXT(TAILQ_FIRST(&find_list), entry) == NULL) {
|
||||||
if (session_select(s, TAILQ_FIRST(&find_list)->wl->idx) == 0)
|
if (session_select(s, TAILQ_FIRST(&find_list)->wl->idx) == 0) {
|
||||||
|
cmd_find_from_session(current, s);
|
||||||
server_redraw_session(s);
|
server_redraw_session(s);
|
||||||
|
}
|
||||||
recalculate_sizes();
|
recalculate_sizes();
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
@ -63,6 +63,7 @@ static enum cmd_retval
|
|||||||
cmd_join_pane_exec(struct cmd *self, struct cmdq_item *item)
|
cmd_join_pane_exec(struct cmd *self, struct cmdq_item *item)
|
||||||
{
|
{
|
||||||
struct args *args = self->args;
|
struct args *args = self->args;
|
||||||
|
struct cmd_find_state *current = &item->shared->current;
|
||||||
struct session *dst_s;
|
struct session *dst_s;
|
||||||
struct winlink *src_wl, *dst_wl;
|
struct winlink *src_wl, *dst_wl;
|
||||||
struct window *src_w, *dst_w;
|
struct window *src_w, *dst_w;
|
||||||
@ -146,6 +147,7 @@ cmd_join_pane_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
if (!args_has(args, 'd')) {
|
if (!args_has(args, 'd')) {
|
||||||
window_set_active_pane(dst_w, src_wp);
|
window_set_active_pane(dst_w, src_wp);
|
||||||
session_select(dst_s, dst_idx);
|
session_select(dst_s, dst_idx);
|
||||||
|
cmd_find_from_session(current, dst_s);
|
||||||
server_redraw_session(dst_s);
|
server_redraw_session(dst_s);
|
||||||
} else
|
} else
|
||||||
server_status_session(dst_s);
|
server_status_session(dst_s);
|
||||||
|
@ -324,8 +324,10 @@ cmd_new_session_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
free(cp);
|
free(cp);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!detached)
|
if (!detached) {
|
||||||
c->flags |= CLIENT_ATTACHED;
|
c->flags |= CLIENT_ATTACHED;
|
||||||
|
cmd_find_from_session(&item->shared->current, s);
|
||||||
|
}
|
||||||
|
|
||||||
if (to_free != NULL)
|
if (to_free != NULL)
|
||||||
free((void *)to_free);
|
free((void *)to_free);
|
||||||
|
@ -52,6 +52,7 @@ static enum cmd_retval
|
|||||||
cmd_new_window_exec(struct cmd *self, struct cmdq_item *item)
|
cmd_new_window_exec(struct cmd *self, struct cmdq_item *item)
|
||||||
{
|
{
|
||||||
struct args *args = self->args;
|
struct args *args = self->args;
|
||||||
|
struct cmd_find_state *current = &item->shared->current;
|
||||||
struct session *s = item->state.tflag.s;
|
struct session *s = item->state.tflag.s;
|
||||||
struct winlink *wl = item->state.tflag.wl;
|
struct winlink *wl = item->state.tflag.wl;
|
||||||
struct client *c = item->state.c;
|
struct client *c = item->state.c;
|
||||||
@ -132,6 +133,7 @@ cmd_new_window_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
}
|
}
|
||||||
if (!detached) {
|
if (!detached) {
|
||||||
session_select(s, wl->idx);
|
session_select(s, wl->idx);
|
||||||
|
cmd_find_from_winlink(current, wl);
|
||||||
server_redraw_session_group(s);
|
server_redraw_session_group(s);
|
||||||
} else
|
} else
|
||||||
server_status_session_group(s);
|
server_status_session_group(s);
|
||||||
|
@ -56,6 +56,7 @@ static enum cmd_retval
|
|||||||
cmd_select_pane_exec(struct cmd *self, struct cmdq_item *item)
|
cmd_select_pane_exec(struct cmd *self, struct cmdq_item *item)
|
||||||
{
|
{
|
||||||
struct args *args = self->args;
|
struct args *args = self->args;
|
||||||
|
struct cmd_find_state *current = &item->shared->current;
|
||||||
struct winlink *wl = item->state.tflag.wl;
|
struct winlink *wl = item->state.tflag.wl;
|
||||||
struct window *w = wl->window;
|
struct window *w = wl->window;
|
||||||
struct session *s = item->state.tflag.s;
|
struct session *s = item->state.tflag.s;
|
||||||
@ -68,7 +69,6 @@ cmd_select_pane_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
cmdq_error(item, "no last pane");
|
cmdq_error(item, "no last pane");
|
||||||
return (CMD_RETURN_ERROR);
|
return (CMD_RETURN_ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (args_has(self->args, 'e'))
|
if (args_has(self->args, 'e'))
|
||||||
lastwp->flags &= ~PANE_INPUTOFF;
|
lastwp->flags &= ~PANE_INPUTOFF;
|
||||||
else if (args_has(self->args, 'd'))
|
else if (args_has(self->args, 'd'))
|
||||||
@ -77,6 +77,7 @@ cmd_select_pane_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
server_unzoom_window(w);
|
server_unzoom_window(w);
|
||||||
window_redraw_active_switch(w, lastwp);
|
window_redraw_active_switch(w, lastwp);
|
||||||
if (window_set_active_pane(w, lastwp)) {
|
if (window_set_active_pane(w, lastwp)) {
|
||||||
|
cmd_find_from_winlink(current, wl);
|
||||||
server_status_window(w);
|
server_status_window(w);
|
||||||
server_redraw_window_borders(w);
|
server_redraw_window_borders(w);
|
||||||
}
|
}
|
||||||
@ -155,6 +156,7 @@ cmd_select_pane_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
}
|
}
|
||||||
window_redraw_active_switch(w, wp);
|
window_redraw_active_switch(w, wp);
|
||||||
if (window_set_active_pane(w, wp)) {
|
if (window_set_active_pane(w, wp)) {
|
||||||
|
cmd_find_from_winlink(current, wl);
|
||||||
server_status_window(w);
|
server_status_window(w);
|
||||||
server_redraw_window_borders(w);
|
server_redraw_window_borders(w);
|
||||||
}
|
}
|
||||||
|
@ -84,6 +84,7 @@ const struct cmd_entry cmd_last_window_entry = {
|
|||||||
static enum cmd_retval
|
static enum cmd_retval
|
||||||
cmd_select_window_exec(struct cmd *self, struct cmdq_item *item)
|
cmd_select_window_exec(struct cmd *self, struct cmdq_item *item)
|
||||||
{
|
{
|
||||||
|
struct cmd_find_state *current = &item->shared->current;
|
||||||
struct winlink *wl = item->state.tflag.wl;
|
struct winlink *wl = item->state.tflag.wl;
|
||||||
struct session *s = item->state.tflag.s;
|
struct session *s = item->state.tflag.s;
|
||||||
int next, previous, last, activity;
|
int next, previous, last, activity;
|
||||||
@ -116,7 +117,7 @@ cmd_select_window_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
return (CMD_RETURN_ERROR);
|
return (CMD_RETURN_ERROR);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
cmd_find_from_session(&item->shared->current, s);
|
||||||
server_redraw_session(s);
|
server_redraw_session(s);
|
||||||
} else {
|
} else {
|
||||||
/*
|
/*
|
||||||
@ -128,10 +129,14 @@ cmd_select_window_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
cmdq_error(item, "no last window");
|
cmdq_error(item, "no last window");
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
|
if (current->s == s)
|
||||||
|
cmd_find_from_session(current, s);
|
||||||
server_redraw_session(s);
|
server_redraw_session(s);
|
||||||
} else if (session_select(s, wl->idx) == 0)
|
} else if (session_select(s, wl->idx) == 0) {
|
||||||
|
cmd_find_from_session(current, s);
|
||||||
server_redraw_session(s);
|
server_redraw_session(s);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
recalculate_sizes();
|
recalculate_sizes();
|
||||||
|
|
||||||
return (CMD_RETURN_NORMAL);
|
return (CMD_RETURN_NORMAL);
|
||||||
|
@ -53,6 +53,7 @@ const struct cmd_entry cmd_split_window_entry = {
|
|||||||
static enum cmd_retval
|
static enum cmd_retval
|
||||||
cmd_split_window_exec(struct cmd *self, struct cmdq_item *item)
|
cmd_split_window_exec(struct cmd *self, struct cmdq_item *item)
|
||||||
{
|
{
|
||||||
|
struct cmd_find_state *current = &item->shared->current;
|
||||||
struct args *args = self->args;
|
struct args *args = self->args;
|
||||||
struct client *c = item->state.c;
|
struct client *c = item->state.c;
|
||||||
struct session *s = item->state.tflag.s;
|
struct session *s = item->state.tflag.s;
|
||||||
@ -156,6 +157,7 @@ cmd_split_window_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
if (!args_has(args, 'd')) {
|
if (!args_has(args, 'd')) {
|
||||||
window_set_active_pane(w, new_wp);
|
window_set_active_pane(w, new_wp);
|
||||||
session_select(s, wl->idx);
|
session_select(s, wl->idx);
|
||||||
|
cmd_find_from_session(current, s);
|
||||||
server_redraw_session(s);
|
server_redraw_session(s);
|
||||||
} else
|
} else
|
||||||
server_status_session(s);
|
server_status_session(s);
|
||||||
|
@ -99,6 +99,7 @@ cmd_switch_client_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
if (wp != NULL)
|
if (wp != NULL)
|
||||||
window_set_active_pane(wp->window, wp);
|
window_set_active_pane(wp->window, wp);
|
||||||
session_set_current(s, state->tflag.wl);
|
session_set_current(s, state->tflag.wl);
|
||||||
|
cmd_find_from_session(&item->shared->current, s);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -856,10 +856,9 @@ server_client_handle_key(struct client *c, key_code key)
|
|||||||
m->valid = 0;
|
m->valid = 0;
|
||||||
|
|
||||||
/* Find affected pane. */
|
/* Find affected pane. */
|
||||||
if (KEYC_IS_MOUSE(key) && m->valid)
|
if (!KEYC_IS_MOUSE(key) || cmd_find_from_mouse(&fs, m) != 0)
|
||||||
wp = cmd_mouse_pane(m, NULL, NULL);
|
cmd_find_from_session(&fs, s);
|
||||||
else
|
wp = fs.wp;
|
||||||
wp = w->active;
|
|
||||||
|
|
||||||
/* Forward mouse keys if disabled. */
|
/* Forward mouse keys if disabled. */
|
||||||
if (KEYC_IS_MOUSE(key) && !options_get_number(s->options, "mouse"))
|
if (KEYC_IS_MOUSE(key) && !options_get_number(s->options, "mouse"))
|
||||||
@ -946,13 +945,8 @@ retry:
|
|||||||
}
|
}
|
||||||
server_status_client(c);
|
server_status_client(c);
|
||||||
|
|
||||||
/* Find default state if the pane is known. */
|
/* Execute the key binding. */
|
||||||
if (KEYC_IS_MOUSE(key) && m->valid && wp != NULL) {
|
|
||||||
cmd_find_from_winlink_pane(&fs, s->curw, wp);
|
|
||||||
cmd_find_log_state(__func__, &fs);
|
|
||||||
key_bindings_dispatch(bd, c, m, &fs);
|
key_bindings_dispatch(bd, c, m, &fs);
|
||||||
} else
|
|
||||||
key_bindings_dispatch(bd, c, m, NULL);
|
|
||||||
key_bindings_unref_table(table);
|
key_bindings_unref_table(table);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user