URI: 
       tFix a few warnings - wendy - watch files/directories and run commands on any event
  HTML git clone git://z3bra.org/wendy
   DIR Log
   DIR Files
   DIR Refs
   DIR README
   DIR LICENSE
       ---
   DIR commit cf3c4f87d5a603669c5c64380f7d2f1e2044dfa8
   DIR parent c94f1359dea6f5e56f9e1347678763e9d89b6a08
  HTML Author: Willy Goiffon <dev@z3bra.org>
       Date:   Tue,  2 Jun 2020 13:21:22 +0200
       
       Fix a few warnings
       
       Diffstat:
         M wendy.c                             |      16 ++++++++++------
       
       1 file changed, 10 insertions(+), 6 deletions(-)
       ---
   DIR diff --git a/wendy.c b/wendy.c
       t@@ -89,7 +89,7 @@ watch(int fd, char *pathname, int mask)
                /* store inode path, eventually removing trailing '/' */
                len = strlcpy(w->path, pathname, PATH_MAX);
                if (w->path[len - 1] == '/')
       -                w->path[len - 1] == '\0';
       +                w->path[len - 1] = '\0';
        
                w->wd = inotify_add_watch(fd, w->path, mask);
                if (w->wd < 0) {
       t@@ -108,7 +108,7 @@ watch(int fd, char *pathname, int mask)
        int
        watchstream(int fd, FILE *stream, int mask)
        {
       -        ssize_t l, n = 0;
       +        size_t l, n = 0;
                char *p = NULL;
        
                while (getline(&p, &n, stream) > 0) {
       t@@ -124,11 +124,15 @@ watchstream(int fd, FILE *stream, int mask)
        char *
        wdpath(struct inotify_event *e, struct watcher *w)
        {
       +        size_t len;
                static char pathname[PATH_MAX];
        
       -        strlcpy(pathname, w->path, PATH_MAX);
       -        if (e->len)
       -                snprintf(pathname, PATH_MAX, "%s/%s", w->path, e->name);
       +        len = strlcpy(pathname, w->path, PATH_MAX);
       +        if (e->len) {
       +                strncat(pathname, "/", PATH_MAX - len - 1);
       +                len = strnlen(pathname, PATH_MAX - 1);
       +                strncat(pathname, e->name, PATH_MAX - len - 1);
       +        }
        
                return pathname;
        }
       t@@ -142,7 +146,7 @@ main (int argc, char **argv)
                uint32_t mask = MASK;
                ssize_t len, off = 0;
                char **cmd, *argv0 = NULL;
       -        struct watcher *tmp, *w;
       +        struct watcher *w;
                struct inotify_event *e;
        
                /* get file descriptor */