Merge branch 'obsd-master'

This commit is contained in:
Thomas Adam 2017-06-23 18:01:11 +01:00
commit 6995497e5b
6 changed files with 50 additions and 3 deletions

View File

@ -240,6 +240,12 @@ cmd_set_option_exec(struct cmd *self, struct cmdq_item *item)
TAILQ_FOREACH(loop, &clients, entry) TAILQ_FOREACH(loop, &clients, entry)
server_client_set_key_table(loop, NULL); server_client_set_key_table(loop, NULL);
} }
if (strcmp(name, "user-keys") == 0) {
TAILQ_FOREACH(loop, &clients, entry) {
if (loop->tty.flags & TTY_OPENED)
tty_keys_build(&loop->tty);
}
}
if (strcmp(name, "status") == 0 || if (strcmp(name, "status") == 0 ||
strcmp(name, "status-interval") == 0) strcmp(name, "status-interval") == 0)
status_timer_start_all(); status_timer_start_all();

View File

@ -110,12 +110,16 @@ static const struct {
static key_code static key_code
key_string_search_table(const char *string) key_string_search_table(const char *string)
{ {
u_int i; u_int i, user;
for (i = 0; i < nitems(key_string_table); i++) { for (i = 0; i < nitems(key_string_table); i++) {
if (strcasecmp(string, key_string_table[i].string) == 0) if (strcasecmp(string, key_string_table[i].string) == 0)
return (key_string_table[i].key); return (key_string_table[i].key);
} }
if (sscanf(string, "User%u", &user) == 1 && user < KEYC_NUSER)
return (KEYC_USER + user);
return (KEYC_UNKNOWN); return (KEYC_UNKNOWN);
} }
@ -265,6 +269,10 @@ key_string_lookup_key(key_code key)
return ("MouseMoveStatus"); return ("MouseMoveStatus");
if (key == KEYC_MOUSEMOVE_BORDER) if (key == KEYC_MOUSEMOVE_BORDER)
return ("MouseMoveBorder"); return ("MouseMoveBorder");
if (key >= KEYC_USER && key < KEYC_USER + KEYC_NUSER) {
snprintf(out, sizeof out, "User%u", (u_int)(key - KEYC_USER));
return (out);
}
/* /*
* Special case: display C-@ as C-Space. Could do this below in * Special case: display C-@ as C-Space. Could do this below in

View File

@ -135,6 +135,13 @@ const struct options_table_entry options_table[] = {
.separator = "," .separator = ","
}, },
{ .name = "user-keys",
.type = OPTIONS_TABLE_ARRAY,
.scope = OPTIONS_TABLE_SERVER,
.default_str = "",
.separator = ","
},
{ .name = "assume-paste-time", { .name = "assume-paste-time",
.type = OPTIONS_TABLE_NUMBER, .type = OPTIONS_TABLE_NUMBER,
.scope = OPTIONS_TABLE_SESSION, .scope = OPTIONS_TABLE_SESSION,

12
tmux.1
View File

@ -2867,6 +2867,18 @@ removed from the session environment (as if
was given to the was given to the
.Ic set-environment .Ic set-environment
command). command).
.It Ic user-keys[] Ar key
Set list of user-defined key escape sequences.
Each item is associated with a key named
.Ql User0,
.Ql User1,
and so on.
.Pp
For example:
.Bd -literal -offset indent
set -s user-keys[0] '\e[5;30012~'
bind User0 resize-pane -L 3
.Ed
.It Xo Ic visual-activity .It Xo Ic visual-activity
.Op Ic on | off .Op Ic on | off
.Xc .Xc

4
tmux.h
View File

@ -91,6 +91,10 @@ struct tmuxproc;
#define KEYC_NONE 0xffff00000000ULL #define KEYC_NONE 0xffff00000000ULL
#define KEYC_UNKNOWN 0xfffe00000000ULL #define KEYC_UNKNOWN 0xfffe00000000ULL
#define KEYC_BASE 0x000010000000ULL #define KEYC_BASE 0x000010000000ULL
#define KEYC_USER 0x000020000000ULL
/* Available user keys. */
#define KEYC_NUSER 1000
/* Key modifier bits. */ /* Key modifier bits. */
#define KEYC_ESCAPE 0x200000000000ULL #define KEYC_ESCAPE 0x200000000000ULL

View File

@ -389,8 +389,9 @@ tty_keys_build(struct tty *tty)
{ {
const struct tty_default_key_raw *tdkr; const struct tty_default_key_raw *tdkr;
const struct tty_default_key_code *tdkc; const struct tty_default_key_code *tdkc;
u_int i; u_int i, size;
const char *s; const char *s, *value;
struct options_entry *o;
if (tty->key_tree != NULL) if (tty->key_tree != NULL)
tty_keys_free(tty); tty_keys_free(tty);
@ -411,6 +412,15 @@ tty_keys_build(struct tty *tty)
tty_keys_add(tty, s, tdkc->key); tty_keys_add(tty, s, tdkc->key);
} }
o = options_get(global_options, "user-keys");
if (o != NULL && options_array_size(o, &size) != -1) {
for (i = 0; i < size; i++) {
value = options_array_get(o, i);
if (value != NULL)
tty_keys_add(tty, value, KEYC_USER + i);
}
}
} }
/* Free the entire key tree. */ /* Free the entire key tree. */