]> git.sur5r.net Git - i3/i3status/commitdiff
Use kill(pid, 0) to check if the process is alive
authorMichael Stapelberg <michael@stapelberg.de>
Sun, 28 Nov 2010 15:45:34 +0000 (16:45 +0100)
committerMichael Stapelberg <michael@stapelberg.de>
Sun, 28 Nov 2010 15:45:34 +0000 (16:45 +0100)
include/i3status.h
src/general.c
src/process_runs.c

index a79be1842812155feacd89246711b8b6dab9723d..0ed0d1f0803144610652d735a7a0a2c6d1b6a634 100644 (file)
@@ -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();
index a093c160d73eb874645f5a1702eda143f6859cea..2ae90f135ed2dad3f6ff788e2905af0b345aa3f1 100644 (file)
@@ -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)
index d8513a53044c64c9be354b5793dcb37c07e6746c..88979f0f72b426b33194adb357cae57e29f4d76e 100644 (file)
@@ -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);
 }