Move pid_running() to process.h

This commit is contained in:
Robbert van der Helm
2022-04-11 13:20:51 +02:00
parent 0d6738093c
commit 60e4619ef1
5 changed files with 30 additions and 25 deletions
-19
View File
@@ -94,25 +94,6 @@ bool is_watchdog_timer_disabled() {
return disable_watchdog_env && disable_watchdog_env == "1"sv;
}
bool pid_running(pid_t pid) {
// With regular individually hosted plugins we can simply check whether the
// process is still running, however Boost.Process does not allow you to do
// the same thing for a process that's not a direct child if this process.
// When using plugin groups we'll have to manually check whether the PID
// returned by the group host process is still active. We sadly can't use
// `kill()` for this as that provides no way to distinguish between active
// processes and zombies, and a terminated group host process will always be
// left as a zombie process. If the process is active, then
// `/proc/<pid>/{cwd,exe,root}` will be valid symlinks.
std::error_code err;
fs::canonical("/proc/" + std::to_string(pid) + "/exe", err);
// NOTE: We can get a `EACCES` here if we don't have permissions to read
// this process's memory. This does mean that the process is still
// running.
return !err || err.value() == EACCES;
}
std::string url_encode_path(std::string path) {
// We only need to escape a couple of special characters here. This is used
// in the notifications as well as in the XDND proxy. We encode the reserved