mirror of
https://github.com/tmux/tmux.git
synced 2025-01-14 20:58:53 +00:00
Add a format client_prefix which is 1 if prefix key has been
pressed, used for example #{?client_prefix,X,Y}. Also a few extra server_client_status needed.
This commit is contained in:
parent
dd76497ab0
commit
63b4fd5cac
5
format.c
5
format.c
@ -251,10 +251,11 @@ format_expand(struct format_tree *ft, const char *fmt)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
while (len - off < 2) {
|
while (len - off < 3) {
|
||||||
buf = xrealloc(buf, 2, len);
|
buf = xrealloc(buf, 2, len);
|
||||||
len *= 2;
|
len *= 2;
|
||||||
}
|
}
|
||||||
|
buf[off++] = '#';
|
||||||
buf[off++] = ch;
|
buf[off++] = ch;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -321,6 +322,8 @@ format_client(struct format_tree *ft, struct client *c)
|
|||||||
*strchr(tim, '\n') = '\0';
|
*strchr(tim, '\n') = '\0';
|
||||||
format_add(ft, "client_activity_string", "%s", tim);
|
format_add(ft, "client_activity_string", "%s", tim);
|
||||||
|
|
||||||
|
format_add(ft, "client_prefix", "%d", !!(c->flags & CLIENT_PREFIX));
|
||||||
|
|
||||||
if (c->tty.flags & TTY_UTF8)
|
if (c->tty.flags & TTY_UTF8)
|
||||||
format_add(ft, "client_utf8", "%d", 1);
|
format_add(ft, "client_utf8", "%d", 1);
|
||||||
else
|
else
|
||||||
|
@ -418,6 +418,7 @@ server_client_handle_key(struct client *c, int key)
|
|||||||
if (!(c->flags & CLIENT_PREFIX)) {
|
if (!(c->flags & CLIENT_PREFIX)) {
|
||||||
if (isprefix) {
|
if (isprefix) {
|
||||||
c->flags |= CLIENT_PREFIX;
|
c->flags |= CLIENT_PREFIX;
|
||||||
|
server_status_client(c);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -432,6 +433,7 @@ server_client_handle_key(struct client *c, int key)
|
|||||||
|
|
||||||
/* Prefix key already pressed. Reset prefix and lookup key. */
|
/* Prefix key already pressed. Reset prefix and lookup key. */
|
||||||
c->flags &= ~CLIENT_PREFIX;
|
c->flags &= ~CLIENT_PREFIX;
|
||||||
|
server_status_client(c);
|
||||||
if ((bd = key_bindings_lookup(key | KEYC_PREFIX)) == NULL) {
|
if ((bd = key_bindings_lookup(key | KEYC_PREFIX)) == NULL) {
|
||||||
/* If repeating, treat this as a key, else ignore. */
|
/* If repeating, treat this as a key, else ignore. */
|
||||||
if (c->flags & CLIENT_REPEAT) {
|
if (c->flags & CLIENT_REPEAT) {
|
||||||
@ -587,8 +589,11 @@ server_client_repeat_timer(unused int fd, unused short events, void *data)
|
|||||||
{
|
{
|
||||||
struct client *c = data;
|
struct client *c = data;
|
||||||
|
|
||||||
if (c->flags & CLIENT_REPEAT)
|
if (c->flags & CLIENT_REPEAT) {
|
||||||
|
if (c->flags & CLIENT_PREFIX)
|
||||||
|
server_status_client(c);
|
||||||
c->flags &= ~(CLIENT_PREFIX|CLIENT_REPEAT);
|
c->flags &= ~(CLIENT_PREFIX|CLIENT_REPEAT);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check if client should be exited. */
|
/* Check if client should be exited. */
|
||||||
|
Loading…
Reference in New Issue
Block a user