summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornicm <nicm@openbsd.org>2017-06-13 07:12:33 +0000
committernicm <nicm@openbsd.org>2017-06-13 07:12:33 +0000
commitf5346fb7aedb57a414942e1c70e6da1b9fa8db9b (patch)
treefb8829d6bf9d96cefcce0512a16917926e450ae9
parentuse size_t for the size of things in memory, not int. (diff)
downloadwireguard-openbsd-f5346fb7aedb57a414942e1c70e6da1b9fa8db9b.tar.xz
wireguard-openbsd-f5346fb7aedb57a414942e1c70e6da1b9fa8db9b.zip
Remove xterm flag from key before checking prefix, reported by Peter
Fern in GitHub issue 974.
-rw-r--r--usr.bin/tmux/server-client.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/usr.bin/tmux/server-client.c b/usr.bin/tmux/server-client.c
index b81772acadc..7b7ef2bc95a 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.238 2017/06/06 15:49:35 nicm Exp $ */
+/* $OpenBSD: server-client.c,v 1.239 2017/06/13 07:12:33 nicm Exp $ */
/*
* Copyright (c) 2009 Nicholas Marriott <nicholas.marriott@gmail.com>
@@ -818,6 +818,7 @@ server_client_handle_key(struct client *c, key_code key)
struct key_binding bd_find, *bd;
int xtimeout, flags;
struct cmd_find_state fs;
+ key_code key0;
/* Check the client is good to accept input. */
if (s == NULL || (c->flags & (CLIENT_DEAD|CLIENT_SUSPENDED)) != 0)
@@ -906,8 +907,9 @@ server_client_handle_key(struct client *c, key_code key)
* The prefix always takes precedence and forces a switch to the prefix
* table, unless we are already there.
*/
- if ((key == (key_code)options_get_number(s->options, "prefix") ||
- key == (key_code)options_get_number(s->options, "prefix2")) &&
+ key0 = (key & ~KEYC_XTERM);
+ if ((key0 == (key_code)options_get_number(s->options, "prefix") ||
+ key0 == (key_code)options_get_number(s->options, "prefix2")) &&
strcmp(table->name, "prefix") != 0) {
server_client_set_key_table(c, "prefix");
server_status_client(c);
@@ -925,7 +927,7 @@ retry:
log_debug("currently repeating");
/* Try to see if there is a key binding in the current table. */
- bd_find.key = (key & ~KEYC_XTERM);
+ bd_find.key = key0;
bd = RB_FIND(key_bindings, &table->key_bindings, &bd_find);
if (bd != NULL) {
/*