Audit mkdir(1)

1) No need for strchr() in mkdirp or a while-loop. Rewrite it in
   a sane and readable way.
2) fix usage according to the manpage.
3) order includes, don't align local variables.
4) argc-style-fix.
5) BUGFIX: Don't try to chmod() *argv when mkdir() / mkdirp() failed.
6) Add newline before return in two places.
This commit is contained in:
FRIGN 2015-03-05 18:03:08 +01:00
parent cb04864692
commit d9fa4b3ae7
2 changed files with 22 additions and 28 deletions

2
README
View File

@ -44,7 +44,7 @@ The following tools are implemented ('*' == finished, '#' == UTF-8 support,
=* logname yes none
= ls no (-C), -S, -f, -m, -s, -x
=*| md5sum non-posix none
=* mkdir yes none
=*| mkdir yes none
=*| mkfifo yes none
=* mktemp non-posix none
=*| mv yes none (-i)

48
mkdir.c
View File

@ -3,7 +3,6 @@
#include <errno.h>
#include <stdlib.h>
#include <string.h>
#include "util.h"
@ -12,33 +11,31 @@ mkdirp(char *path)
{
char *p = path;
do {
if (*p && (p = strchr(&p[1], '/')))
*p = '\0';
if (mkdir(path, S_IRWXU|S_IRWXG|S_IRWXO) < 0 && errno != EEXIST) {
for (p = path; *p; p++) {
if (*p != '/')
continue;
*p = '\0';
if (mkdir(path, S_IRWXU | S_IRWXG | S_IRWXO) < 0 && errno != EEXIST) {
weprintf("mkdir %s:", path);
return -1;
}
if (p)
*p = '/';
} while (p);
*p = '/';
}
return 0;
}
static void
usage(void)
{
eprintf("usage: %s [-p] [-m mode] directory ...\n", argv0);
eprintf("usage: %s [-p] [-m mode] name ...\n", argv0);
}
int
main(int argc, char *argv[])
{
mode_t mode = 0;
mode_t mask;
int pflag = 0;
int mflag = 0;
int ret = 0;
mode_t mode = 0, mask;
int pflag = 0, mflag = 0, ret = 0;
ARGBEGIN {
case 'p':
@ -53,23 +50,20 @@ main(int argc, char *argv[])
usage();
} ARGEND;
if (argc < 1)
if (!argc)
usage();
for (; argc > 0; argc--, argv++) {
if (pflag) {
if (mkdirp(argv[0]) < 0)
ret = 1;
} else if (mkdir(argv[0], S_IRWXU|S_IRWXG|S_IRWXO) < 0) {
weprintf("mkdir %s:", argv[0]);
for (; *argv; argc--, argv++) {
if (pflag && mkdirp(*argv) < 0) {
ret = 1;
} else if (!pflag && mkdir(*argv, S_IRWXU | S_IRWXG | S_IRWXO) < 0) {
weprintf("mkdir %s:", *argv);
ret = 1;
} else if (mflag && chmod(*argv, mode) < 0) {
weprintf("chmod %s:", *argv);
ret = 1;
}
if (mflag) {
if (chmod(argv[0], mode) < 0) {
weprintf("chmod %s:", argv[0]);
ret = 1;
}
}
}
return ret;
}