Do not require that there be no other clients before loading the config,

being the first client is enough. GitHub issue 2438.
This commit is contained in:
nicm 2020-10-28 10:09:10 +00:00 committed by Nicholas Marriott
parent 977cf3cf69
commit 7a4aa14618

View File

@ -2237,7 +2237,7 @@ server_client_dispatch_identify(struct client *c, struct imsg *imsg)
c->fd = open(c->ttyname, O_RDWR|O_NOCTTY);
#endif
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) {
@ -2252,13 +2252,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();
}