diff options
author | 2016-09-12 15:40:58 +0000 | |
---|---|---|
committer | 2016-09-12 15:40:58 +0000 | |
commit | 26ddb2f512259df3dda523d7649d0e93a95c6d98 (patch) | |
tree | 761545f0c4cd8e08f67726886abed22c7d9ed53c /usr.bin/tmux/cmd-list-keys.c | |
parent | Add data about how long the session has been in the current state, and (diff) | |
download | wireguard-openbsd-26ddb2f512259df3dda523d7649d0e93a95c6d98.tar.xz wireguard-openbsd-26ddb2f512259df3dda523d7649d0e93a95c6d98.zip |
Allow repeat count to be specified in mode key tables with bind-key -R,
and set the default repeat count to 5 for WheelUp and WheelDown in
copy-mode.
Diffstat (limited to 'usr.bin/tmux/cmd-list-keys.c')
-rw-r--r-- | usr.bin/tmux/cmd-list-keys.c | 33 |
1 files changed, 23 insertions, 10 deletions
diff --git a/usr.bin/tmux/cmd-list-keys.c b/usr.bin/tmux/cmd-list-keys.c index b79b78c62dc..2a033bc224d 100644 --- a/usr.bin/tmux/cmd-list-keys.c +++ b/usr.bin/tmux/cmd-list-keys.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cmd-list-keys.c,v 1.35 2016/06/15 08:54:11 nicm Exp $ */ +/* $OpenBSD: cmd-list-keys.c,v 1.36 2016/09/12 15:40:58 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott <nicholas.marriott@gmail.com> @@ -135,11 +135,11 @@ static enum cmd_retval cmd_list_keys_table(struct cmd *self, struct cmd_q *cmdq) { struct args *args = self->args; - const char *tablename; + const char *tablename, *key, *cmdstr, *mode; const struct mode_key_table *mtab; struct mode_key_binding *mbind; - const char *key, *cmdstr, *mode; - int width, keywidth, any_mode; + char repeat[16]; + int width, keywidth, repeatwidth, any_mode; tablename = args_get(args, 't'); if ((mtab = mode_key_findtable(tablename)) == NULL) { @@ -147,7 +147,7 @@ cmd_list_keys_table(struct cmd *self, struct cmd_q *cmdq) return (CMD_RETURN_ERROR); } - width = 0; + keywidth = repeatwidth = 0; any_mode = 0; RB_FOREACH(mbind, mode_key_tree, mtab->tree) { key = key_string_lookup_key(mbind->key); @@ -155,9 +155,16 @@ cmd_list_keys_table(struct cmd *self, struct cmd_q *cmdq) if (mbind->mode != 0) any_mode = 1; - keywidth = strlen(key); - if (keywidth > width) - width = keywidth; + width = strlen(key); + if (width > keywidth) + keywidth = width; + + if (mbind->repeat != 1) { + snprintf(repeat, sizeof repeat, "%u", mbind->repeat); + width = strlen(repeat); + if (width > repeatwidth) + repeatwidth = width; + } } RB_FOREACH(mbind, mode_key_tree, mtab->tree) { @@ -166,11 +173,17 @@ cmd_list_keys_table(struct cmd *self, struct cmd_q *cmdq) mode = ""; if (mbind->mode != 0) mode = "c"; + snprintf(repeat, sizeof repeat, "%u", mbind->repeat); cmdstr = mode_key_tostring(mtab->cmdstr, mbind->cmd); if (cmdstr != NULL) { - cmdq_print(cmdq, "bind-key -%st %s%s %*s %s%s%s%s", + cmdq_print(cmdq, + "bind-key -%st %s%s%s%*s %*s %s%s%s%s", mode, any_mode && *mode == '\0' ? " " : "", - mtab->name, (int) width, key, cmdstr, + mtab->name, + mbind->repeat != 1 ? " -R " : + (repeatwidth == 0 ? "" : " "), + repeatwidth, mbind->repeat != 1 ? repeat : "", + (int)keywidth, key, cmdstr, mbind->arg != NULL ? " \"" : "", mbind->arg != NULL ? mbind->arg : "", mbind->arg != NULL ? "\"": ""); |