Rename lib files to and prefix lib function names
[khatus.git] / x5 / khatus.c
index ccfce96..5ba94d3 100644 (file)
@@ -14,8 +14,8 @@
 #include <X11/Xlib.h>
 
 #include "bsdtimespec.h"
-#include "khatus_lib_log.h"
-#include "khatus_lib_time.h"
+#include "khlib_log.h"
+#include "khlib_time.h"
 
 #define usage(...) { \
        print_usage(); \
@@ -51,13 +51,6 @@ struct Config {
        int    fifo_count;
        int    total_width;
        int    output_to_x_root_window;
-} defaults = {
-       .interval    = 1.0,
-       .separator   = "|",
-       .fifos       = NULL,
-       .fifo_count  = 0,
-       .total_width = 0,
-       .output_to_x_root_window = 0,
 };
 
 enum read_status {
@@ -70,7 +63,7 @@ enum read_status {
 void
 fifo_print_one(Fifo *f)
 {
-       info("Fifo "
+       khlib_info("Fifo "
            "{"
            " name = %s,"
            " fd = %d,"
@@ -107,7 +100,7 @@ fifo_print_all(Fifo *head)
 void
 config_print(Config *cfg)
 {
-       info(
+       khlib_info(
            "Config "
            "{"
            " interval = %f,"
@@ -227,7 +220,7 @@ parse_opts_opt_l(Config *cfg, int argc, char *argv[], int i)
                    log_level,
                    Debug
                );
-       _khatus_lib_log_level = log_level;
+       _khlib_log_level = log_level;
        opts_parse_any(cfg, argc, argv, i);
 }
 
@@ -282,7 +275,7 @@ parse_opts_spec(Config *cfg, int argc, char *argv[], int i)
                f->name      = n;
                f->fd        = -1;
                f->width     = atoi(w);
-               f->ttl       = timespec_of_float(atof(t));
+               f->ttl       = khlib_timespec_of_float(atof(t));
                f->last_read = last_read;
                f->pos_init  = cfg->total_width;
                f->pos_curr  = f->pos_init;
@@ -293,7 +286,7 @@ parse_opts_spec(Config *cfg, int argc, char *argv[], int i)
                cfg->total_width += f->width;
                cfg->fifo_count++;
        } else {
-               fatal("[memory] Allocation failure.");
+               khlib_fatal("[memory] Allocation failure.");
        }
        opts_parse_any(cfg, argc, argv, i);
 }
@@ -336,7 +329,7 @@ fifo_expire(Fifo *f, struct timespec t, char *buf)
        if (timespeccmp(&td, &(f->ttl), >=)) {
                /* TODO: Maybe configurable expiry character. */
                memset(buf + f->pos_init, '_', f->pos_final - f->pos_init);
-               warn("Data source expired: \"%s\"\n", f->name);
+               khlib_warn("Data source expired: \"%s\"\n", f->name);
        }
 }
 
@@ -365,8 +358,10 @@ fifo_read_one(Fifo *f, struct timespec t, char *buf)
        for (;;) {
                switch (read(f->fd, &c, 1)) {
                case -1:
-                       error("Failed to read: \"%s\". errno: %d, msg: %s\n",
-                           f->name, errno, strerror(errno));
+                       khlib_error(
+                           "Failed to read: \"%s\". errno: %d, msg: %s\n",
+                           f->name, errno, strerror(errno)
+                       );
                        switch (errno) {
                        case EINTR:
                        case EAGAIN:
@@ -375,7 +370,7 @@ fifo_read_one(Fifo *f, struct timespec t, char *buf)
                                return FAILURE;
                        }
                case  0:
-                       debug("%s: End of FILE\n", f->name);
+                       khlib_debug("%s: End of FILE\n", f->name);
                        f->pos_curr = f->pos_init;
                        return END_OF_FILE;
                case  1:
@@ -391,6 +386,11 @@ fifo_read_one(Fifo *f, struct timespec t, char *buf)
                                if (f->pos_curr <= f->pos_final)
                                        buf[f->pos_curr++] = c;
                                /* Drop beyond available range. */
+                               /*
+                                * TODO Define max after which we stop reading.
+                                *      To ensure that a rogue large message
+                                *      doesn't trap us here.
+                                */
                        }
                        break;
                default:
@@ -412,7 +412,7 @@ fifo_read_all(Config *cfg, struct timespec *ti, char *buf)
        for (Fifo *f = cfg->fifos; f; f = f->next) {
                /* TODO: Create the FIFO if it doesn't already exist. */
                if (lstat(f->name, &st) < 0) {
-                       error(
+                       khlib_error(
                            "Cannot stat \"%s\". Error: %s\n",
                            f->name,
                            strerror(errno)
@@ -421,48 +421,64 @@ fifo_read_all(Config *cfg, struct timespec *ti, char *buf)
                        continue;
                }
                if (!(st.st_mode & S_IFIFO)) {
-                       error("\"%s\" is not a FIFO\n", f->name);
+                       khlib_error("\"%s\" is not a FIFO\n", f->name);
                        fifo_read_error(f, buf);
                        continue;
                }
                if (f->fd < 0) {
-                       debug("%s: closed. opening. fd: %d\n", f->name, f->fd);
+                       khlib_debug(
+                           "%s: closed. opening. fd: %d\n",
+                           f->name,
+                           f->fd
+                       );
                        f->fd = open(f->name, O_RDONLY | O_NONBLOCK);
                } else {
-                       debug("%s: already openned. fd: %d\n", f->name, f->fd);
+                       khlib_debug(
+                           "%s: already openned. fd: %d\n",
+                           f->name,
+                           f->fd
+                       );
                }
                if (f->fd == -1) {
                        /* TODO Consider backing off retries for failed fifos */
-                       error("Failed to open \"%s\"\n", f->name);
+                       khlib_error("Failed to open \"%s\"\n", f->name);
                        fifo_read_error(f, buf);
                        continue;
                }
-               debug("%s: open. fd: %d\n", f->name, f->fd);
+               khlib_debug("%s: open. fd: %d\n", f->name, f->fd);
                if (f->fd > maxfd)
                        maxfd = f->fd;
                FD_SET(f->fd, &fds);
        }
-       debug("selecting...\n");
+       khlib_debug("selecting...\n");
        ready = pselect(maxfd + 1, &fds, NULL, NULL, ti, NULL);
-       debug("ready: %d\n", ready);
+       khlib_debug("ready: %d\n", ready);
        clock_gettime(CLOCK_MONOTONIC, &t);
        if (ready == -1) {
                switch (errno) {
                case EINTR:
-                       error("pselect temp failure: %d, errno: %d, msg: %s\n",
-                           ready, errno, strerror(errno));
+                       khlib_error(
+                           "pselect temp failure: %d, errno: %d, msg: %s\n",
+                           ready,
+                           errno,
+                           strerror(errno)
+                       );
                        /* TODO: Reconsider what to do here. */
                        return;
                default:
-                       fatal("pselect failed: %d, errno: %d, msg: %s\n",
-                           ready, errno, strerror(errno));
+                       khlib_fatal(
+                           "pselect failed: %d, errno: %d, msg: %s\n",
+                           ready,
+                           errno,
+                           strerror(errno)
+                       );
                }
        }
        /* At-least-once ensures that expiries are still checked on timeouts. */
        do {
                for (Fifo *f = cfg->fifos; f; f = f->next) {
                        if (FD_ISSET(f->fd, &fds)) {
-                               debug("reading: %s\n", f->name);
+                               khlib_debug("reading: %s\n", f->name);
                                switch (fifo_read_one(f, t, buf)) {
                                /*
                                 * ### MESSAGE LOSS ###
@@ -501,14 +517,21 @@ fifo_read_all(Config *cfg, struct timespec *ti, char *buf)
 int
 main(int argc, char *argv[])
 {
+       Config cfg = {
+               .interval    = 1.0,
+               .separator   = "|",
+               .fifos       = NULL,
+               .fifo_count  = 0,
+               .total_width = 0,
+               .output_to_x_root_window = 0,
+       };
+
        int width  = 0;
        int nfifos = 0;
        int seplen = 0;
        int prefix = 0;
        int errors = 0;
        char *buf;
-       Config cfg0 = defaults;
-       Config *cfg = &cfg0;
        Display *d = NULL;
        struct stat st;
        struct timespec
@@ -520,19 +543,19 @@ main(int argc, char *argv[])
 
        argv0 = argv[0];
 
-       opts_parse(cfg, argc, argv);
-       debug("argv0 = %s\n", argv0);
-       config_print(cfg);
+       opts_parse(&cfg, argc, argv);
+       khlib_debug("argv0 = %s\n", argv0);
+       config_print(&cfg);
 
-       ti = timespec_of_float(cfg->interval);
+       ti = khlib_timespec_of_float(cfg.interval);
 
-       if (cfg->fifos == NULL)
+       if (cfg.fifos == NULL)
                usage("No fifo specs were given!\n");
 
        /* 1st pass to check file existence and type */
-       for (Fifo *f = cfg->fifos; f; f = f->next) {
+       for (Fifo *f = cfg.fifos; f; f = f->next) {
                if (lstat(f->name, &st) < 0) {
-                       error(
+                       khlib_error(
                            "Cannot stat \"%s\". Error: %s\n",
                            f->name,
                            strerror(errno)
@@ -541,19 +564,21 @@ main(int argc, char *argv[])
                        continue;
                }
                if (!(st.st_mode & S_IFIFO)) {
-                       error("\"%s\" is not a FIFO\n", f->name);
+                       khlib_error("\"%s\" is not a FIFO\n", f->name);
                        errors++;
                        continue;
                }
        }
        if (errors)
-               fatal("Encountered errors with given file paths. See log.\n");
+               khlib_fatal(
+                   "Encountered errors with given file paths. See log.\n"
+               );
 
-       width  = cfg->total_width;
-       seplen = strlen(cfg->separator);
+       width  = cfg.total_width;
+       seplen = strlen(cfg.separator);
 
        /* 2nd pass to make space for separators */
-       for (Fifo *f = cfg->fifos; f; f = f->next) {
+       for (Fifo *f = cfg.fifos; f; f = f->next) {
                f->pos_init  += prefix;
                f->pos_final += prefix;
                f->pos_curr = f->pos_init;
@@ -563,30 +588,33 @@ main(int argc, char *argv[])
        width += (seplen * (nfifos - 1));
        buf = calloc(1, width + 1);
        if (buf == NULL)
-               fatal("[memory] Failed to allocate buffer of %d bytes", width);
+               khlib_fatal(
+                   "[memory] Failed to allocate buffer of %d bytes",
+                   width
+               );
        memset(buf, ' ', width);
        buf[width] = '\0';
        /* 3rd pass to set the separators */
-       for (Fifo *f = cfg->fifos; f; f = f->next) {
+       for (Fifo *f = cfg.fifos; f; f = f->next) {
                if (f->pos_init) {  /* Skip the first, left-most */
                        /* Copying only seplen ensures we omit the '\0' byte. */
                        strncpy(
                            buf + (f->pos_init - seplen),
-                           cfg->separator,
+                           cfg.separator,
                            seplen
                        );
                }
        }
 
-       if (cfg->output_to_x_root_window && !(d = XOpenDisplay(NULL)))
-               fatal("XOpenDisplay failed with: %p\n", d);
+       if (cfg.output_to_x_root_window && !(d = XOpenDisplay(NULL)))
+               khlib_fatal("XOpenDisplay failed with: %p\n", d);
        /* TODO: Handle signals */
        for (;;) {
                clock_gettime(CLOCK_MONOTONIC, &t0); // FIXME: check errors
-               fifo_read_all(cfg, &ti, buf);
-               if (cfg->output_to_x_root_window) {
+               fifo_read_all(&cfg, &ti, buf);
+               if (cfg.output_to_x_root_window) {
                        if (XStoreName(d, DefaultRootWindow(d), buf) < 0)
-                               fatal("XStoreName failed.\n");
+                               khlib_fatal("XStoreName failed.\n");
                        XFlush(d);
                } else {
                        puts(buf);
@@ -594,7 +622,7 @@ main(int argc, char *argv[])
                }
                clock_gettime(CLOCK_MONOTONIC, &t1); // FIXME: check errors
                timespecsub(&t1, &t0, &td);
-               debug(
+               khlib_debug(
                    "td {tv_sec = %ld, tv_nsec = %ld}\n",
                    td.tv_sec,
                    td.tv_nsec
@@ -604,10 +632,10 @@ main(int argc, char *argv[])
                         * pipe more frequently than the interval.
                         */
                        timespecsub(&ti, &td, &tc);
-                       debug("snooze YES\n");
-                       snooze(&tc);
+                       khlib_debug("khlib_sleep YES\n");
+                       khlib_sleep(&tc);
                } else {
-                       debug("snooze NO\n");
+                       khlib_debug("khlib_sleep NO\n");
                }
        }
 
This page took 0.039332 seconds and 4 git commands to generate.