summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Stapelberg <michael@stapelberg.de>2010-11-28 16:45:34 +0100
committerMichael Stapelberg <michael@stapelberg.de>2010-11-28 16:45:34 +0100
commitcf091024335052e4774d44179e80e1948da8610f (patch)
tree3d02b32bdc1de833f8f201256e7945b0ae347e86
parent75670ba64a43f3382e5163b6ea7bf27de28d929b (diff)
Use kill(pid, 0) to check if the process is alive
-rw-r--r--include/i3status.h2
-rw-r--r--src/general.c2
-rw-r--r--src/process_runs.c45
3 files changed, 13 insertions, 36 deletions
diff --git a/include/i3status.h b/include/i3status.h
index a79be18..0ed0d1f 100644
--- a/include/i3status.h
+++ b/include/i3status.h
@@ -51,7 +51,7 @@ typedef enum { CS_DISCHARGING, CS_CHARGING, CS_FULL } charging_status_t;
/* src/general.c */
char *skip_character(char *input, char character, int amount);
void die(const char *fmt, ...);
-bool slurp(char *filename, char *destination, int size);
+bool slurp(const char *filename, char *destination, int size);
/* src/output.c */
void print_seperator();
diff --git a/src/general.c b/src/general.c
index a093c16..2ae90f1 100644
--- a/src/general.c
+++ b/src/general.c
@@ -13,7 +13,7 @@
* Reads size bytes into the destination buffer from filename.
*
*/
-bool slurp(char *filename, char *destination, int size) {
+bool slurp(const char *filename, char *destination, int size) {
int fd;
if ((fd = open(filename, O_RDONLY)) == -1)
diff --git a/src/process_runs.c b/src/process_runs.c
index d8513a5..88979f0 100644
--- a/src/process_runs.c
+++ b/src/process_runs.c
@@ -3,54 +3,31 @@
#include <glob.h>
#include <string.h>
#include <sys/types.h>
-#include <sys/stat.h>
-#include <fcntl.h>
-#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
-
-#ifndef LINUX
-/* TODO: correctly check for *BSD */
-#include <sys/param.h>
-#include <sys/sysctl.h>
-#include <sys/resource.h>
-#endif
+#include <errno.h>
+#include <signal.h>
#include "i3status.h"
/*
- * Checks if the PID in path is still valid by checking:
- * (Linux) if /proc/<pid> exists
- * (NetBSD) if sysctl returns process infos for this pid
+ * Checks if the PID in path is still valid by sending signal 0 (does not do
+ * anything). kill() will return ESRCH if the process does not exist and 0 or
+ * EPERM (depending on the uid) if it exists.
*
*/
bool process_runs(const char *path) {
- char pidbuf[16];
+ static char pidbuf[16];
static glob_t globbuf;
- int fd;
memset(pidbuf, 0, sizeof(pidbuf));
if (glob(path, GLOB_NOCHECK | GLOB_TILDE, NULL, &globbuf) < 0)
die("glob() failed\n");
- fd = open((globbuf.gl_pathc > 0 ? globbuf.gl_pathv[0] : path), O_RDONLY);
- globfree(&globbuf);
- if (fd < 0)
+ if (!slurp((globbuf.gl_pathc > 0 ? globbuf.gl_pathv[0] : path), pidbuf, sizeof(pidbuf))) {
+ globfree(&globbuf);
return false;
- (void)read(fd, pidbuf, sizeof(pidbuf));
- (void)close(fd);
+ }
+ globfree(&globbuf);
-#if defined(LINUX) || defined(__GNU__) || defined(__GLIBC__)
- struct stat statbuf;
- char procbuf[512];
- (void)snprintf(procbuf, sizeof(procbuf), "/proc/%ld", strtol(pidbuf, NULL, 10));
- return (stat(procbuf, &statbuf) >= 0);
-#else
- /* TODO: correctly check for NetBSD. Evaluate if this runs on OpenBSD/FreeBSD */
- struct kinfo_proc info;
- size_t length = sizeof(struct kinfo_proc);
- int mib[4] = { CTL_KERN, KERN_PROC, KERN_PROC_PID, strtol(pidbuf, NULL, 10) };
- if (sysctl(mib, 4, &info, &length, NULL, 0) < 0)
- return false;
- return (length != 0);
-#endif
+ return (kill(strtol(pidbuf, NULL, 10), 0) == 0 || errno == EPERM);
}