unix/PidFile: use raw file descriptor instead of stdio
This commit is contained in:
@@ -25,20 +25,19 @@
|
|||||||
#include "Log.hxx"
|
#include "Log.hxx"
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <stdio.h>
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
|
||||||
class PidFile {
|
class PidFile {
|
||||||
FILE *file;
|
int fd;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
PidFile(const AllocatedPath &path):file(nullptr) {
|
PidFile(const AllocatedPath &path):fd(-1) {
|
||||||
if (path.IsNull())
|
if (path.IsNull())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
file = FOpen(path, FOpenMode::WriteText);
|
fd = OpenFile(path, O_WRONLY|O_CREAT|O_TRUNC, 0666);
|
||||||
if (file == nullptr) {
|
if (fd < 0) {
|
||||||
const std::string utf8 = path.ToUTF8();
|
const std::string utf8 = path.ToUTF8();
|
||||||
FormatFatalSystemError("Failed to create pid file \"%s\"",
|
FormatFatalSystemError("Failed to create pid file \"%s\"",
|
||||||
utf8.c_str());
|
utf8.c_str());
|
||||||
@@ -48,34 +47,35 @@ public:
|
|||||||
PidFile(const PidFile &) = delete;
|
PidFile(const PidFile &) = delete;
|
||||||
|
|
||||||
void Close() {
|
void Close() {
|
||||||
if (file == nullptr)
|
if (fd < 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
fclose(file);
|
close(fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Delete(const AllocatedPath &path) {
|
void Delete(const AllocatedPath &path) {
|
||||||
if (file == nullptr) {
|
if (fd < 0) {
|
||||||
assert(path.IsNull());
|
assert(path.IsNull());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
assert(!path.IsNull());
|
assert(!path.IsNull());
|
||||||
|
|
||||||
fclose(file);
|
close(fd);
|
||||||
RemoveFile(path);
|
RemoveFile(path);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Write(pid_t pid) {
|
void Write(pid_t pid) {
|
||||||
if (file == nullptr)
|
if (fd < 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
fprintf(file, "%lu\n", (unsigned long)pid);
|
char buffer[64];
|
||||||
fclose(file);
|
sprintf(buffer, "%lu\n", (unsigned long)pid);
|
||||||
|
close(fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Write() {
|
void Write() {
|
||||||
if (file == nullptr)
|
if (fd < 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
Write(getpid());
|
Write(getpid());
|
||||||
@@ -86,15 +86,24 @@ gcc_pure
|
|||||||
static inline pid_t
|
static inline pid_t
|
||||||
ReadPidFile(Path path)
|
ReadPidFile(Path path)
|
||||||
{
|
{
|
||||||
FILE *fp = FOpen(path, PATH_LITERAL("r"));
|
int fd = OpenFile(path, O_RDONLY, 0);
|
||||||
if (fp == nullptr)
|
if (fd < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
int pid;
|
pid_t pid = -1;
|
||||||
if (fscanf(fp, "%i", &pid) != 1)
|
|
||||||
pid = -1;
|
|
||||||
|
|
||||||
fclose(fp);
|
char buffer[32];
|
||||||
|
auto nbytes = read(fd, buffer, sizeof(buffer) - 1);
|
||||||
|
if (nbytes > 0) {
|
||||||
|
buffer[nbytes] = 0;
|
||||||
|
|
||||||
|
char *endptr;
|
||||||
|
auto value = strtoul(buffer, &endptr, 10);
|
||||||
|
if (endptr > buffer)
|
||||||
|
pid = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
close(fd);
|
||||||
return pid;
|
return pid;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user