X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=src%2Fprint_path_exists.c;h=87601b439d39c18300a126ece164fd34da53f8fe;hb=ee946d0d8c49f164fde0f863a5fffb646d20db27;hp=1b231e6f78ef6afa140852bfa1c5cde23718ce1e;hpb=d74e904bf4bdd7f1d767a8db09987b90de809579;p=i3%2Fi3status diff --git a/src/print_path_exists.c b/src/print_path_exists.c index 1b231e6..87601b4 100644 --- a/src/print_path_exists.c +++ b/src/print_path_exists.c @@ -1,4 +1,5 @@ // vim:ts=4:sw=4:expandtab +#include #include #include #include @@ -6,28 +7,36 @@ #include #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; - } - if (BEGINS_WITH(walk + 1, "title")) { + } 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", (exists ? "yes" : "no")); walk += strlen("status"); + + } else { + *(outwalk++) = '%'; } }