From 2ab016bd7e0fbdec5f67fd6940e78e320de96469 Mon Sep 17 00:00:00 2001 From: nicm Date: Tue, 17 Jul 2018 18:02:40 +0000 Subject: [PATCH] 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. --- usr.bin/tmux/server-client.c | 27 ++++++++++++++++----------- 1 file 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 @@ -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) -- 2.20.1