[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[PATCH 1/4] Add '-0 / --print0' to herbstclient



---
 doc/herbstclient.txt |  3 +++
 ipc-client/main.c    | 21 ++++++++++++++++++---
 2 files changed, 21 insertions(+), 3 deletions(-)

diff --git a/doc/herbstclient.txt b/doc/herbstclient.txt
index ceb3282..2b2173d 100644
--- a/doc/herbstclient.txt
+++ b/doc/herbstclient.txt
@@ -35,6 +35,9 @@ OPTIONS
 *-n*, *--no-newline*::
     Do not print a newline if output does not end with a newline.
 
+*-0*, *--print0*::
+    Use the null character as output delimiter. This option implies *-n*.
+
 *-i*, *--idle*::
     Wait for hooks instead of executing commands.
 
diff --git a/ipc-client/main.c b/ipc-client/main.c
index 61471d8..2df482f 100644
--- a/ipc-client/main.c
+++ b/ipc-client/main.c
@@ -24,6 +24,7 @@ void init_hook_regex(int argc, char* argv[]);
 void destroy_hook_regex();
 
 int g_ensure_newline = 1; // if set, output ends with a newline
+bool g_null_char_as_delim = false; // if true, the null character is used as delimiter
 int g_wait_for_hook = 0; // if set, do not execute command but wait
 bool g_quiet = false;
 regex_t* g_hook_regex = NULL;
@@ -80,6 +81,8 @@ void print_help(char* command, FILE* file) {
         "Options:\n"
         "\t-n, --no-newline: Do not print a newline if output does not end "
             "with a newline.\n"
+        "\t-0, --print0: Use the null character as output delimiter. "
+            "This option implies '-n'.\n"
         "\t-i, --idle: Wait for hooks instead of executing commands.\n"
         "\t-w, --wait: Same as --idle but exit after first --count hooks.\n"
         "\t-c, --count COUNT: Let --wait exit after COUNT hooks were "
@@ -129,7 +132,11 @@ int main_hook(int argc, char* argv[]) {
             for (int i = 0; i < hook_argc; i++) {
                 printf("%s%s", i ? "\t" : "", hook_argv[i]);
             }
-            printf("\n");
+            if (g_null_char_as_delim) {
+                putchar(0);
+            } else {
+                printf("\n");
+            }
             fflush(stdout);
         }
         argv_free(hook_argc, hook_argv);
@@ -151,6 +158,7 @@ int main_hook(int argc, char* argv[]) {
 int main(int argc, char* argv[]) {
     static struct option long_options[] = {
         {"no-newline", 0, 0, 'n'},
+        {"print0", 0, 0, '0'},
         {"wait", 0, 0, 'w'},
         {"count", 1, 0, 'c'},
         {"idle", 0, 0, 'i'},
@@ -162,7 +170,7 @@ int main(int argc, char* argv[]) {
     // parse options
     while (1) {
         int option_index = 0;
-        int c = getopt_long(argc, argv, "+nwc:iqhv", long_options, &option_index);
+        int c = getopt_long(argc, argv, "+n0wc:iqhv", long_options, &option_index);
         if (c == -1) break;
         switch (c) {
             case 'i':
@@ -179,6 +187,11 @@ int main(int argc, char* argv[]) {
             case 'n':
                 g_ensure_newline = 0;
                 break;
+            case '0':
+                g_null_char_as_delim = true;
+                // '-0' implies '-n'
+                g_ensure_newline = 0;
+                break;
             case 'q':
                 g_quiet = true;
                 break;
@@ -217,7 +230,9 @@ int main(int argc, char* argv[]) {
             file = stderr;
         }
         fputs(output->str, file);
-        if (g_ensure_newline) {
+        if (g_null_char_as_delim) {
+            fputc(0, file);
+        } else if (g_ensure_newline) {
             if (output->len > 0 && output->str[output->len - 1] != '\n') {
                 fputs("\n", file);
             }
-- 
1.9.1