summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2018-08-08 16:59:53 -0400
committerNick Mathewson <nickm@torproject.org>2018-08-08 16:59:53 -0400
commit622a2c6bee19af3bab0e84702a36ff2df39db7e7 (patch)
tree041dc73981ec66bed2b335512979101071cd4487 /src
parent4f300d547d65e50ac1fd635f8b22714c1544ba33 (diff)
downloadtor-622a2c6bee19af3bab0e84702a36ff2df39db7e7.tar.gz
tor-622a2c6bee19af3bab0e84702a36ff2df39db7e7.zip
Make finish_daemon() return a boolean to say whether it did anything.
Diffstat (limited to 'src')
-rw-r--r--src/lib/process/daemon.c9
-rw-r--r--src/lib/process/daemon.h2
2 files changed, 7 insertions, 4 deletions
diff --git a/src/lib/process/daemon.c b/src/lib/process/daemon.c
index 671579838e..4836b3951c 100644
--- a/src/lib/process/daemon.c
+++ b/src/lib/process/daemon.c
@@ -102,15 +102,16 @@ start_daemon(void)
/** Finish putting the process into daemon mode: drop standard fds, and tell
* the parent process to exit. (Note: it's safe to call this more than once:
* calls after the first are ignored. Calls start_daemon first if it hasn't
- * been called already.)
+ * been called already.) Return true if we actually did a fork; false if we
+ * didn't.
*/
-void
+int
finish_daemon(const char *desired_cwd)
{
int nullfd;
char c = '.';
if (finish_daemon_called)
- return;
+ return 0;
if (!start_daemon_called)
start_daemon();
finish_daemon_called = 1;
@@ -149,6 +150,8 @@ finish_daemon(const char *desired_cwd)
log_err(LD_GENERAL,"write failed. Exiting.");
}
close(daemon_filedes[1]);
+
+ return 0;
}
#else /* !(!defined(_WIN32)) */
/* defined(_WIN32) */
diff --git a/src/lib/process/daemon.h b/src/lib/process/daemon.h
index 1f26e92221..08cab17e12 100644
--- a/src/lib/process/daemon.h
+++ b/src/lib/process/daemon.h
@@ -12,6 +12,6 @@
#define TOR_DAEMON_H
void start_daemon(void);
-void finish_daemon(const char *desired_cwd);
+int finish_daemon(const char *desired_cwd);
#endif