@@ -82,6 +82,14 @@ daemon_usage(void)
"unexpected failure. \n");
}
+/* Sets up a following call to service_start() to detach from the foreground
+ * session, running this process in the background. */
+void
+set_detach(void)
+{
+ detach = true;
+}
+
/* Registers the call-back and configures the actions in case of a failure
* with the Windows services manager. */
void
@@ -357,7 +365,7 @@ detach_process(int argc, char *argv[])
/* We are only interested in the '--detach' and '--pipe-handle'. */
for (i = 0; i < argc; i ++) {
- if (!strcmp(argv[i], "--detach")) {
+ if (!detach && !strcmp(argv[i], "--detach")) {
detach = true;
} else if (!strncmp(argv[i], "--pipe-handle", 13)) {
/* If running as a child, return. */
@@ -121,6 +121,7 @@ pid_t read_pidfile(const char *name);
#define DAEMON_OPTION_HANDLERS \
case OPT_DETACH: \
+ set_detach(); \
break; \
\
case OPT_NO_SELF_CONFINEMENT: \
@@ -139,6 +140,7 @@ pid_t read_pidfile(const char *name);
break; \
\
case OPT_SERVICE: \
+ set_detach(); \
break; \
\
case OPT_SERVICE_MONITOR: \
@@ -159,6 +161,7 @@ pid_t read_pidfile(const char *name);
void control_handler(DWORD request);
void set_pipe_handle(const char *pipe_handle);
+void set_detach(void);
#endif /* _WIN32 */
bool get_detach(void);