diff options
author | 2018-07-17 18:02:40 +0000 | |
---|---|---|
committer | 2018-07-17 18:02:40 +0000 | |
commit | 2ab016bd7e0fbdec5f67fd6940e78e320de96469 (patch) | |
tree | 8c44fb46b48e30ef5e30f77789d70a79a7abfddb /usr.bin/tmux/server-client.c | |
parent | some more style fixes (diff) | |
download | wireguard-openbsd-2ab016bd7e0fbdec5f67fd6940e78e320de96469.tar.xz wireguard-openbsd-2ab016bd7e0fbdec5f67fd6940e78e320de96469.zip |
When a key isn't in the first table, we need to try the same key again
not the any key. Also rename some labels. Fixes GitHub issue 1406
reeported by Mark Kelly.
Diffstat (limited to 'usr.bin/tmux/server-client.c')
-rw-r--r-- | usr.bin/tmux/server-client.c | 27 |
1 files changed, 16 insertions, 11 deletions
diff --git a/usr.bin/tmux/server-client.c b/usr.bin/tmux/server-client.c index 95eb17e0701..41ac6edc4b5 100644 --- a/usr.bin/tmux/server-client.c +++ b/usr.bin/tmux/server-client.c @@ -1,4 +1,4 @@ -/* $OpenBSD: server-client.c,v 1.252 2018/07/16 08:48:22 nicm Exp $ */ +/* $OpenBSD: server-client.c,v 1.253 2018/07/17 18:02:40 nicm Exp $ */ /* * Copyright (c) 2009 Nicholas Marriott <nicholas.marriott@gmail.com> @@ -884,11 +884,11 @@ server_client_handle_key(struct client *c, key_code key) /* Forward mouse keys if disabled. */ if (KEYC_IS_MOUSE(key) && !options_get_number(s->options, "mouse")) - goto forward; + goto forward_key; /* Treat everything as a regular key when pasting is detected. */ if (!KEYC_IS_MOUSE(key) && server_client_assume_paste(s)) - goto forward; + goto forward_key; /* * Work out the current key table. If the pane is in a mode, use @@ -903,12 +903,12 @@ server_client_handle_key(struct client *c, key_code key) table = c->keytable; first = table; +table_changed: /* * The prefix always takes precedence and forces a switch to the prefix * table, unless we are already there. */ key0 = (key & ~KEYC_XTERM); -retry: if ((key0 == (key_code)options_get_number(s->options, "prefix") || key0 == (key_code)options_get_number(s->options, "prefix2")) && strcmp(table->name, "prefix") != 0) { @@ -926,6 +926,7 @@ retry: if (c->flags & CLIENT_REPEAT) log_debug("currently repeating"); +try_again: /* Try to see if there is a key binding in the current table. */ bd_find.key = key0; bd = RB_FIND(key_bindings, &table->key_bindings, &bd_find); @@ -941,7 +942,7 @@ retry: c->flags &= ~CLIENT_REPEAT; server_status_client(c); table = c->keytable; - goto retry; + goto table_changed; } log_debug("found in key table %s", table->name); @@ -976,21 +977,25 @@ retry: } /* - * No match in this table. If not in the root table or if repeating, - * switch the client back to the root table and try again. + * No match, try the ANY key. */ - log_debug("not found in key table %s", table->name); if (key0 != KEYC_ANY) { key0 = KEYC_ANY; - goto retry; + goto try_again; } + + /* + * No match in this table. If not in the root table or if repeating, + * switch the client back to the root table and try again. + */ + log_debug("not found in key table %s", table->name); if (!server_client_is_default_key_table(c, table) || (c->flags & CLIENT_REPEAT)) { server_client_set_key_table(c, NULL); c->flags &= ~CLIENT_REPEAT; server_status_client(c); table = c->keytable; - goto retry; + goto table_changed; } /* @@ -1003,7 +1008,7 @@ retry: return; } -forward: +forward_key: if (c->flags & CLIENT_READONLY) return; if (wp != NULL) |