diff options
author | Michael Stapelberg <stapelberg@users.noreply.github.com> | 2015-04-02 13:42:47 -0700 |
---|---|---|
committer | Michael Stapelberg <stapelberg@users.noreply.github.com> | 2015-04-02 13:42:47 -0700 |
commit | d00a0e087c79475e199ff33a33a3e73fcd2c0a22 (patch) | |
tree | 437e4a87d31bb8e1173c88bee00e4e8230cfc5b9 /src | |
parent | f3ccd8ac7d9e258bda123303b1c254c6cdfd0463 (diff) | |
parent | 5c094a54932edebf6e44c4a7119fa510ddf7ae7a (diff) |
Merge pull request #17 from chrko/format_down
Adding format_down option to path_exists and run_watch
Diffstat (limited to 'src')
-rw-r--r-- | src/print_path_exists.c | 10 | ||||
-rw-r--r-- | src/print_run_watch.c | 10 |
2 files changed, 16 insertions, 4 deletions
diff --git a/src/print_path_exists.c b/src/print_path_exists.c index 1b231e6..65bc9c8 100644 --- a/src/print_path_exists.c +++ b/src/print_path_exists.c @@ -6,17 +6,23 @@ #include <sys/stat.h> #include "i3status.h" -void print_path_exists(yajl_gen json_gen, char *buffer, const char *title, const char *path, const char *format) { +void print_path_exists(yajl_gen json_gen, char *buffer, const char *title, const char *path, const char *format, const char *format_down) { const char *walk; char *outwalk = buffer; struct stat st; const bool exists = (stat(path, &st) == 0); + if (exists || format_down == NULL) { + walk = format; + } else { + walk = format_down; + } + INSTANCE(path); START_COLOR((exists ? "color_good" : "color_bad")); - for (walk = format; *walk != '\0'; walk++) { + for (; *walk != '\0'; walk++) { if (*walk != '%') { *(outwalk++) = *walk; continue; diff --git a/src/print_run_watch.c b/src/print_run_watch.c index 3d1ec3f..b108f8f 100644 --- a/src/print_run_watch.c +++ b/src/print_run_watch.c @@ -5,16 +5,22 @@ #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) { +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; + if (running || format_down == NULL) { + walk = format; + } else { + walk = format_down; + } + INSTANCE(pidfile); START_COLOR((running ? "color_good" : "color_bad")); - for (walk = format; *walk != '\0'; walk++) { + for (; *walk != '\0'; walk++) { if (*walk != '%') { *(outwalk++) = *walk; continue; |