summaryrefslogtreecommitdiffstats
path: root/status.c
diff options
context:
space:
mode:
authornicm <nicm>2017-05-01 12:20:55 +0000
committernicm <nicm>2017-05-01 12:20:55 +0000
commit0ccfb61bb0e0beb5fe76b64e30637de7d9f696c7 (patch)
treebf5f11802d7ec1338ee17e893591bdae80d2c197 /status.c
parenta2dd7daf4e583ebb9ddc9d7cf09105c43df51399 (diff)
In order that people can use formats like #D in #() in the status line
and not have to wait for an update when they change pane, we allow commands to run more than once a second if the expanded form changes. Unfortunately this can mean them being run far too often (pretty much continually) when multiple clients exist, because some formats (including #D) will always differ between clients. To avoid this, give each client its own tree of jobs which means that the same command will be different instances for each client - similar to how we have the tag to separate commands for different panes. GitHub issue 889; test case reported by Paul Johnson.
Diffstat (limited to 'status.c')
-rw-r--r--status.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/status.c b/status.c
index c673860a..077c2bf1 100644
--- a/status.c
+++ b/status.c
@@ -519,9 +519,9 @@ status_replace(struct client *c, struct winlink *wl, const char *fmt, time_t t)
else
tag = FORMAT_NONE;
if (c->flags & CLIENT_STATUSFORCE)
- ft = format_create(NULL, tag, FORMAT_STATUS|FORMAT_FORCE);
+ ft = format_create(c, NULL, tag, FORMAT_STATUS|FORMAT_FORCE);
else
- ft = format_create(NULL, tag, FORMAT_STATUS);
+ ft = format_create(c, NULL, tag, FORMAT_STATUS);
format_defaults(ft, c, NULL, wl, NULL);
expanded = format_expand_time(ft, fmt, t);
@@ -663,7 +663,7 @@ status_prompt_set(struct client *c, const char *msg, const char *input,
time_t t;
char *tmp;
- ft = format_create(NULL, FORMAT_NONE, 0);
+ ft = format_create(c, NULL, FORMAT_NONE, 0);
format_defaults(ft, c, NULL, NULL, NULL);
t = time(NULL);
@@ -724,7 +724,7 @@ status_prompt_update(struct client *c, const char *msg, const char *input)
time_t t;
char *tmp;
- ft = format_create(NULL, FORMAT_NONE, 0);
+ ft = format_create(c, NULL, FORMAT_NONE, 0);
format_defaults(ft, c, NULL, NULL, NULL);
t = time(NULL);