diff options
author | Max Kellermann <max@duempel.org> | 2014-01-18 12:10:20 +0100 |
---|---|---|
committer | Max Kellermann <max@duempel.org> | 2014-01-18 12:10:20 +0100 |
commit | 5f3b79e21d88595c53fb9e8b36b312187f4a7b5c (patch) | |
tree | 89af32a9b4202dacf32981f3d5857dab5c6d50f4 /src/Daemon.cxx | |
parent | 56c12bd1eae4318c1eae7cfed0196b886a35c918 (diff) | |
download | mpd-5f3b79e21d88595c53fb9e8b36b312187f4a7b5c.tar.gz mpd-5f3b79e21d88595c53fb9e8b36b312187f4a7b5c.tar.xz mpd-5f3b79e21d88595c53fb9e8b36b312187f4a7b5c.zip |
Daemon: move code to class PidFile
Diffstat (limited to '')
-rw-r--r-- | src/Daemon.cxx | 24 |
1 files changed, 5 insertions, 19 deletions
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 <stdio.h> #include <stdlib.h> #include <unistd.h> #include <fcntl.h> @@ -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 |