mirror of
https://github.com/tmux/tmux.git
synced 2025-04-03 14:28:50 +00:00
Add a prefix timeout option, from Conor Taylor in GitHub issue 4108.
This commit is contained in:
parent
3a8a31d8d2
commit
d8b66110f7
@ -386,6 +386,17 @@ const struct options_table_entry options_table[] = {
|
|||||||
.text = "Maximum number of server messages to keep."
|
.text = "Maximum number of server messages to keep."
|
||||||
},
|
},
|
||||||
|
|
||||||
|
{ .name = "prefix-timeout",
|
||||||
|
.type = OPTIONS_TABLE_NUMBER,
|
||||||
|
.scope = OPTIONS_TABLE_SERVER,
|
||||||
|
.minimum = 0,
|
||||||
|
.maximum = INT_MAX,
|
||||||
|
.default_num = 0,
|
||||||
|
.unit = "milliseconds",
|
||||||
|
.text = "The timeout for the prefix key if no subsequent key is "
|
||||||
|
"pressed. Zero means disabled."
|
||||||
|
},
|
||||||
|
|
||||||
{ .name = "prompt-history-limit",
|
{ .name = "prompt-history-limit",
|
||||||
.type = OPTIONS_TABLE_NUMBER,
|
.type = OPTIONS_TABLE_NUMBER,
|
||||||
.scope = OPTIONS_TABLE_SERVER,
|
.scope = OPTIONS_TABLE_SERVER,
|
||||||
|
@ -226,6 +226,17 @@ server_client_set_key_table(struct client *c, const char *name)
|
|||||||
key_bindings_unref_table(c->keytable);
|
key_bindings_unref_table(c->keytable);
|
||||||
c->keytable = key_bindings_get_table(name, 1);
|
c->keytable = key_bindings_get_table(name, 1);
|
||||||
c->keytable->references++;
|
c->keytable->references++;
|
||||||
|
if (gettimeofday(&c->keytable->activity_time, NULL) != 0)
|
||||||
|
fatal("gettimeofday failed");
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint64_t
|
||||||
|
server_client_key_table_activity_diff(struct client *c)
|
||||||
|
{
|
||||||
|
struct timeval diff;
|
||||||
|
|
||||||
|
timersub(&c->activity_time, &c->keytable->activity_time, &diff);
|
||||||
|
return ((diff.tv_sec * 1000ULL) + (diff.tv_usec / 1000ULL));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get default key table. */
|
/* Get default key table. */
|
||||||
@ -1870,7 +1881,7 @@ server_client_key_callback(struct cmdq_item *item, void *data)
|
|||||||
struct key_table *table, *first;
|
struct key_table *table, *first;
|
||||||
struct key_binding *bd;
|
struct key_binding *bd;
|
||||||
int xtimeout;
|
int xtimeout;
|
||||||
uint64_t flags;
|
uint64_t flags, prefix_delay;
|
||||||
struct cmd_find_state fs;
|
struct cmd_find_state fs;
|
||||||
key_code key0, prefix, prefix2;
|
key_code key0, prefix, prefix2;
|
||||||
|
|
||||||
@ -1965,8 +1976,34 @@ try_again:
|
|||||||
if (c->flags & CLIENT_REPEAT)
|
if (c->flags & CLIENT_REPEAT)
|
||||||
log_debug("currently repeating");
|
log_debug("currently repeating");
|
||||||
|
|
||||||
/* Try to see if there is a key binding in the current table. */
|
|
||||||
bd = key_bindings_get(table, key0);
|
bd = key_bindings_get(table, key0);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If prefix-timeout is enabled and we're in the prefix table, see if
|
||||||
|
* the timeout has been exceeded. Revert to the root table if so.
|
||||||
|
*/
|
||||||
|
prefix_delay = options_get_number(global_options, "prefix-timeout");
|
||||||
|
if (prefix_delay > 0 &&
|
||||||
|
strcmp(table->name, "prefix") == 0 &&
|
||||||
|
server_client_key_table_activity_diff(c) > prefix_delay) {
|
||||||
|
/*
|
||||||
|
* If repeating is active and this is a repeating binding,
|
||||||
|
* ignore the timeout.
|
||||||
|
*/
|
||||||
|
if (bd != NULL &&
|
||||||
|
(c->flags & CLIENT_REPEAT) &&
|
||||||
|
(bd->flags & KEY_BINDING_REPEAT)) {
|
||||||
|
log_debug("prefix timeout ignored, repeat is active");
|
||||||
|
} else {
|
||||||
|
log_debug("prefix timeout exceeded");
|
||||||
|
server_client_set_key_table(c, NULL);
|
||||||
|
first = table = c->keytable;
|
||||||
|
server_status_client(c);
|
||||||
|
goto table_changed;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Try to see if there is a key binding in the current table. */
|
||||||
if (bd != NULL) {
|
if (bd != NULL) {
|
||||||
/*
|
/*
|
||||||
* Key was matched in this table. If currently repeating but a
|
* Key was matched in this table. If currently repeating but a
|
||||||
|
1
tmux.h
1
tmux.h
@ -1982,6 +1982,7 @@ RB_HEAD(key_bindings, key_binding);
|
|||||||
|
|
||||||
struct key_table {
|
struct key_table {
|
||||||
const char *name;
|
const char *name;
|
||||||
|
struct timeval activity_time;
|
||||||
struct key_bindings key_bindings;
|
struct key_bindings key_bindings;
|
||||||
struct key_bindings default_key_bindings;
|
struct key_bindings default_key_bindings;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user