Commit 8de41406 by Richard Weinberger Committed by Stéphane Graber

utils: reimplement/fix mkdir_p()

Reimplement mkdir_p() such that it: ...handles relativ paths correctly. (currently it crashes) ...does not rely on dirname(). ...is not recursive. ...is shorter. ;-) Signed-off-by: 's avatarRichard Weinberger <richard@nod.at> Acked-by: 's avatarSerge E. Hallyn <serge.hallyn@ubuntu.com>
parent 5a5c35c3
......@@ -95,39 +95,25 @@ extern int get_u16(unsigned short *val, const char *arg, int base)
return 0;
}
static int is_all_slashes(char *path)
{
while (*path && *path == '/')
path++;
if (*path)
return 0;
return 1;
}
extern int mkdir_p(char *dir, mode_t mode)
{
int ret;
char *d;
if (is_all_slashes(dir))
return 0;
d = strdup(dir);
if (!d)
return -1;
ret = mkdir_p(dirname(d), mode);
free(d);
if (ret)
return -1;
if (!access(dir, F_OK))
return 0;
if (mkdir(dir, mode)) {
SYSERROR("failed to create directory '%s'\n", dir);
return -1;
}
char *tmp = dir;
char *orig = dir;
char *makeme;
do {
dir = tmp + strspn(tmp, "/");
tmp = dir + strcspn(dir, "/");
makeme = strndupa(orig, dir - orig);
if (*makeme) {
if (!access(makeme, F_OK))
return 0;
if (mkdir(makeme, mode)) {
SYSERROR("failed to create directory '%s'\n", makeme);
return -1;
}
}
} while(tmp != dir);
return 0;
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment