diff options
author | nicm <nicm> | 2017-05-01 12:20:55 +0000 |
---|---|---|
committer | nicm <nicm> | 2017-05-01 12:20:55 +0000 |
commit | 0ccfb61bb0e0beb5fe76b64e30637de7d9f696c7 (patch) | |
tree | bf5f11802d7ec1338ee17e893591bdae80d2c197 /status.c | |
parent | a2dd7daf4e583ebb9ddc9d7cf09105c43df51399 (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.c | 8 |
1 files changed, 4 insertions, 4 deletions
@@ -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); |