sbase

suckless unix tools
git clone git://git.suckless.org/sbase
Log | Files | Refs | README | LICENSE

commit efabd56535a00456434b909ce5709866a910a28c
parent b445614f7021c76902ad2ed41e4d3d0087b04e98
Author: sin <sin@2f30.org>
Date:   Thu, 11 Feb 2016 10:00:00 +0000

Minor cleanup for pathchk(1)

Diffstat:
Mpathchk.c | 39+++++++++++++++------------------------
1 file changed, 15 insertions(+), 24 deletions(-)

diff --git a/pathchk.c b/pathchk.c @@ -8,28 +8,13 @@ #include <sys/stat.h> #include "util.h" -#include "arg.h" #define PORTABLE_CHARACTER_SET "0123456789._-qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM" /* If your system supports more other characters, but not all non-NUL characters, define SYSTEM_CHARACTER_SET. */ -#ifndef PATH_MAX -# define PATH_MAX SIZE_MAX -#endif -#ifndef NAME_MAX -# define NAME_MAX SIZE_MAX -#endif - static int most = 0; static int extra = 0; -static void -usage(void) -{ - fprintf(stderr, "usage: %s [-pP] filename...\n", argv0); - exit(1); -} - static int pathchk(char *filename) { @@ -40,13 +25,13 @@ pathchk(char *filename) /* Empty? */ if (extra && !*filename) { - fprintf(stderr, "%s: empty filename\n", argv0); + weprintf("%s: empty filename\n", argv0); return 1; } /* Leading hyphen? */ if (extra && ((*filename == '-') || strstr(filename, "/-"))) { - fprintf(stderr, "%s: %s: leading '-' in component of filename\n", argv0, filename); + weprintf("%s: %s: leading '-' in component of filename\n", argv0, filename); return 1; } @@ -60,9 +45,9 @@ pathchk(char *filename) character_set = "/"PORTABLE_CHARACTER_SET; if (character_set && *(invalid = filename + strspn(filename, character_set))) { for (invalid_end = invalid + 1; *invalid_end & 0x80; invalid_end++); - fprintf(stderr, "%s: %s: ", argv0, filename); + weprintf("%s: %s: ", argv0, filename); *invalid_end = 0; - fprintf(stderr, "nonportable character '%s'\n", invalid); + weprintf("nonportable character '%s'\n", invalid); return 1; } @@ -70,15 +55,15 @@ pathchk(char *filename) if (lstat(filename, &_attr) && errno != ENOENT) { /* lstat rather than stat, so that if filename is a bad symlink, but * all parents are OK, no error will be detected. */ - fprintf(stderr, "%s: %s: %s\n", argv0, filename, strerror(errno)); + weprintf("%s: %s:", argv0, filename); return 1; } /* Too long pathname? */ maxlen = most ? _POSIX_PATH_MAX : PATH_MAX; if (strlen(filename) >= maxlen) { - fprintf(stderr, "%s: %s: is longer than %zu bytes\n", - argv0, filename, maxlen); + weprintf("%s: %s: is longer than %zu bytes\n", + argv0, filename, maxlen); return 1; } @@ -88,8 +73,8 @@ pathchk(char *filename) q = strchr(p, '/'); len = q ? (size_t)(q++ - p) : strlen(p); if (len > maxlen) { - fprintf(stderr, "%s: %s: includes component longer than %zu bytes\n", - argv0, filename, maxlen); + weprintf("%s: %s: includes component longer than %zu bytes\n", + argv0, filename, maxlen); return 1; } } @@ -97,6 +82,12 @@ pathchk(char *filename) return 0; } +static void +usage(void) +{ + eprintf("usage: %s [-pP] filename...\n", argv0); +} + int main(int argc, char *argv[]) {