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:
Nicholas Marriott 2013-03-21 16:14:09 +00:00
parent dd76497ab0
commit 63b4fd5cac
2 changed files with 10 additions and 2 deletions

View File

@ -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

View File

@ -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. */