aboutsummaryrefslogtreecommitdiff
path: root/server-client.c
diff options
context:
space:
mode:
authornicm <nicm>2020-10-28 10:09:10 +0000
committernicm <nicm>2020-10-28 10:09:10 +0000
commitb33a302235affc19d8a1d8f7473fe589d1bcd17e (patch)
tree132b53cbd00829ed262bd16c2f47fcb459631871 /server-client.c
parent31ed29e5511958845fabc66a479eeec39c1836bd (diff)
downloadrtmux-b33a302235affc19d8a1d8f7473fe589d1bcd17e.tar.gz
rtmux-b33a302235affc19d8a1d8f7473fe589d1bcd17e.tar.bz2
rtmux-b33a302235affc19d8a1d8f7473fe589d1bcd17e.zip
Do not require that there be no other clients before loading the config,
being the first client is enough. GitHub issue 2438.
Diffstat (limited to 'server-client.c')
-rw-r--r--server-client.c12
1 files changed, 6 insertions, 6 deletions
diff --git a/server-client.c b/server-client.c
index efeec85b..4c9706f7 100644
--- a/server-client.c
+++ b/server-client.c
@@ -2243,7 +2243,7 @@ server_client_dispatch_identify(struct client *c, struct imsg *imsg)
c->name = name;
log_debug("client %p name is %s", c, c->name);
- if (c->flags & CLIENT_CONTROL)
+ if (c->flags & CLIENT_CONTROL)
control_start(c);
else if (c->fd != -1) {
if (tty_init(&c->tty, c) != 0) {
@@ -2258,13 +2258,13 @@ server_client_dispatch_identify(struct client *c, struct imsg *imsg)
}
/*
- * If this is the first client that has finished identifying, load
- * configuration files.
+ * If this is the first client, load configuration files. Any later
+ * clients are allowed to continue with their command even if the
+ * config has not been loaded - they might have been run from inside it
*/
if ((~c->flags & CLIENT_EXIT) &&
- !cfg_finished &&
- c == TAILQ_FIRST(&clients) &&
- TAILQ_NEXT(c, entry) == NULL)
+ !cfg_finished &&
+ c == TAILQ_FIRST(&clients))
start_cfg();
}