summaryrefslogtreecommitdiffstats
path: root/server.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicholas.marriott@gmail.com>2008-06-02 21:16:21 +0000
committerNicholas Marriott <nicholas.marriott@gmail.com>2008-06-02 21:16:21 +0000
commit259dcbbc9326689ab7e982a73ebbeff947f7260f (patch)
tree1d23c26a28cfe12f64b39b1c72caa88591f2a85d /server.c
parent70dc1b10f28d00c915719c055b8b566d9dda63ba (diff)
Daemonise before loading configuration.
Diffstat (limited to 'server.c')
-rw-r--r--server.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/server.c b/server.c
index ed64b424..8264b155 100644
--- a/server.c
+++ b/server.c
@@ -1,4 +1,4 @@
-/* $Id: server.c,v 1.47 2008-06-02 21:08:36 nicm Exp $ */
+/* $Id: server.c,v 1.48 2008-06-02 21:16:21 nicm Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -78,6 +78,13 @@ server_start(const char *path)
xmalloc_clear();
#endif
+ /*
+ * Must daemonise before loading configuration as the PID changes so
+ * $TMUX would be wrong for sessions created in the config file.
+ */
+ if (daemon(1, 1) != 0)
+ fatal("daemon failed");
+
ARRAY_INIT(&windows);
ARRAY_INIT(&clients);
ARRAY_INIT(&sessions);
@@ -120,10 +127,6 @@ server_start(const char *path)
fatal("fcntl failed");
if (fcntl(fd, F_SETFD, FD_CLOEXEC) == -1)
fatal("fcntl failed");
-
- if (daemon(1, 1) != 0)
- fatal("daemon failed");
- log_debug("server daemonised, pid now %ld", (long) getpid());
n = server_main(path, fd);
#ifdef DEBUG