From f5346fb7aedb57a414942e1c70e6da1b9fa8db9b Mon Sep 17 00:00:00 2001 From: nicm Date: Tue, 13 Jun 2017 07:12:33 +0000 Subject: [PATCH] Remove xterm flag from key before checking prefix, reported by Peter Fern in GitHub issue 974. --- usr.bin/tmux/server-client.c | 10 ++++++---- 1 file 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 @@ -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) { /* -- 2.20.1