]> git.sur5r.net Git - i3/i3status/blobdiff - src/print_run_watch.c
Switch to autotools (#316)
[i3/i3status] / src / print_run_watch.c
index f93c3a0e02c3d086c1de3c906bdc993ae31fb87f..f0a0746b0984d46dfef18267b151b95d2a18c277 100644 (file)
@@ -1,32 +1,43 @@
+// vim:ts=4:sw=4:expandtab
+#include <config.h>
 #include <stdio.h>
 #include <string.h>
 #include <yajl/yajl_gen.h>
+#include <yajl/yajl_version.h>
 #include "i3status.h"
 
-void print_run_watch(yajl_gen json_gen, char *buffer, const char *title, const char *pidfile, const char *format) {
-       bool running = process_runs(pidfile);
-       const char *walk;
-       char *outwalk = buffer;
+void print_run_watch(yajl_gen json_gen, char *buffer, const char *title, const char *pidfile, const char *format, const char *format_down) {
+    bool running = process_runs(pidfile);
+    const char *walk;
+    char *outwalk = buffer;
 
-       INSTANCE(pidfile);
+    if (running || format_down == NULL) {
+        walk = format;
+    } else {
+        walk = format_down;
+    }
 
-       START_COLOR((running ? "color_good" : "color_bad"));
+    INSTANCE(pidfile);
 
-        for (walk = format; *walk != '\0'; walk++) {
-                if (*walk != '%') {
-                       *(outwalk++) = *walk;
-                        continue;
-                }
+    START_COLOR((running ? "color_good" : "color_bad"));
 
-                if (strncmp(walk+1, "title", strlen("title")) == 0) {
-                       outwalk += sprintf(outwalk, "%s", title);
-                        walk += strlen("title");
-                } else if (strncmp(walk+1, "status", strlen("status")) == 0) {
-                       outwalk += sprintf(outwalk, "%s", (running ? "yes" : "no"));
-                        walk += strlen("status");
-                }
+    for (; *walk != '\0'; walk++) {
+        if (*walk != '%') {
+            *(outwalk++) = *walk;
+
+        } else if (BEGINS_WITH(walk + 1, "title")) {
+            outwalk += sprintf(outwalk, "%s", title);
+            walk += strlen("title");
+
+        } else if (BEGINS_WITH(walk + 1, "status")) {
+            outwalk += sprintf(outwalk, "%s", (running ? "yes" : "no"));
+            walk += strlen("status");
+
+        } else {
+            *(outwalk++) = '%';
         }
+    }
 
-       END_COLOR;
-       OUTPUT_FULL_TEXT(buffer);
+    END_COLOR;
+    OUTPUT_FULL_TEXT(buffer);
 }