Commit 567bf445 authored by Max Kellermann's avatar Max Kellermann

unix/Daemon: move code to ReadPidFile()

parent 28a0c46c
...@@ -65,25 +65,15 @@ static int detach_fd = -1; ...@@ -65,25 +65,15 @@ static int detach_fd = -1;
void void
daemonize_kill(void) daemonize_kill(void)
{ {
FILE *fp;
int pid;
if (pidfile.IsNull()) if (pidfile.IsNull())
FatalError("no pid_file specified in the config file"); FatalError("no pid_file specified in the config file");
fp = FOpen(pidfile, PATH_LITERAL("r")); const pid_t pid = ReadPidFile(pidfile);
if (fp == nullptr) { if (pid < 0) {
const std::string utf8 = pidfile.ToUTF8();
FormatFatalSystemError("Unable to open pid file \"%s\"",
utf8.c_str());
}
if (fscanf(fp, "%i", &pid) != 1) {
const std::string utf8 = pidfile.ToUTF8(); const std::string utf8 = pidfile.ToUTF8();
FormatFatalError("unable to read the pid from file \"%s\"", FormatFatalError("unable to read the pid from file \"%s\"",
utf8.c_str()); utf8.c_str());
} }
fclose(fp);
if (kill(pid, SIGTERM) < 0) if (kill(pid, SIGTERM) < 0)
FormatFatalSystemError("unable to kill process %i", FormatFatalSystemError("unable to kill process %i",
......
...@@ -82,4 +82,20 @@ public: ...@@ -82,4 +82,20 @@ public:
} }
}; };
gcc_pure
static inline pid_t
ReadPidFile(Path path)
{
FILE *fp = FOpen(path, PATH_LITERAL("r"));
if (fp == nullptr)
return -1;
int pid;
if (fscanf(fp, "%i", &pid) != 1)
pid = -1;
fclose(fp);
return pid;
}
#endif #endif
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment