diff options
author | Mike Frysinger <vapier@gentoo.org> | 2009-03-29 00:50:30 +0000 |
---|---|---|
committer | Mike Frysinger <vapier@gentoo.org> | 2009-03-29 00:50:30 +0000 |
commit | 40b8dc410e12e6111b2897f385847a0f3ec720c7 (patch) | |
tree | 6b4658685e3f61151712fefd570084990efaa94e /shell | |
parent | 8ec1c9dc6ead6605dd8e88d407e0c84a4d309818 (diff) |
use bb_strtou() in umask/wait and check errno to see if there was a problem rather than using endp
Diffstat (limited to 'shell')
-rw-r--r-- | shell/hush.c | 11 |
1 files changed, 4 insertions, 7 deletions
diff --git a/shell/hush.c b/shell/hush.c index 9f0e7f809..5203f2eef 100644 --- a/shell/hush.c +++ b/shell/hush.c @@ -4892,12 +4892,10 @@ static int builtin_umask(char **argv) { mode_t new_umask; const char *arg = argv[1]; - char *end; if (arg) { - new_umask = strtoul(arg, &end, 8); - if (*end != '\0' || end == arg) { + new_umask = bb_strtou(arg, NULL, 8); + if (errno) return EXIT_FAILURE; - } } else { new_umask = umask(0); printf("%.3o\n", (unsigned) new_umask); @@ -4924,9 +4922,8 @@ static int builtin_wait(char **argv) wait(&status); while (argv[1]) { - char *endp; - pid_t pid = bb_strtou(argv[1], &endp, 10); - if (*endp) { + pid_t pid = bb_strtou(argv[1], NULL, 10); + if (errno) { bb_perror_msg("wait %s", argv[1]); return EXIT_FAILURE; } else if (waitpid(pid, &status, 0) == pid) { |