From 5f3b79e21d88595c53fb9e8b36b312187f4a7b5c Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Sat, 18 Jan 2014 12:10:20 +0100 Subject: Daemon: move code to class PidFile --- src/Daemon.cxx | 24 +++++------------------- 1 file changed, 5 insertions(+), 19 deletions(-) (limited to 'src/Daemon.cxx') diff --git a/src/Daemon.cxx b/src/Daemon.cxx index 2425e74c4..f11a6e547 100644 --- a/src/Daemon.cxx +++ b/src/Daemon.cxx @@ -23,9 +23,9 @@ #include "fs/AllocatedPath.hxx" #include "fs/FileSystem.hxx" #include "util/Domain.hxx" +#include "PidFile.hxx" #include "Log.hxx" -#include #include #include #include @@ -164,28 +164,14 @@ daemonize_detach(void) void daemonize(bool detach) { - FILE *fp = nullptr; - - if (!pidfile.IsNull()) { - /* do this before daemon'izing so we can fail gracefully if we can't - * write to the pid file */ - LogDebug(daemon_domain, "opening pid file"); - fp = FOpen(pidfile, "w+"); - if (!fp) { - const std::string utf8 = pidfile.ToUTF8(); - FormatFatalSystemError("Failed to create pid file \"%s\"", - pidfile.c_str()); - } - } + /* do this before daemon'izing so we can fail gracefully if we + can't write to the pid file */ + PidFile pidfile2(pidfile); if (detach) daemonize_detach(); - if (!pidfile.IsNull()) { - LogDebug(daemon_domain, "writing pid file"); - fprintf(fp, "%lu\n", (unsigned long)getpid()); - fclose(fp); - } + pidfile2.Write(); } void -- cgit v1.2.3