Should no longer fail if a directory already exists when using -p

This commit is contained in:
Pierre Pronchery 2005-04-05 22:11:04 +00:00
parent e3ed4ef6a2
commit cb1a91577c

View File

@ -12,6 +12,7 @@ extern char * optarg;
/* mkdir */ /* mkdir */
static int _mkdir_error(char * message, int ret);
static int _mkdir_p(mode_t mode, char * pathname); static int _mkdir_p(mode_t mode, char * pathname);
static int _mkdir(int flagp, mode_t mode, int argc, char * argv[]) static int _mkdir(int flagp, mode_t mode, int argc, char * argv[])
{ {
@ -23,22 +24,29 @@ static int _mkdir(int flagp, mode_t mode, int argc, char * argv[])
if(flagp == 1) if(flagp == 1)
{ {
if(_mkdir_p(mode, argv[i]) != 0) if(_mkdir_p(mode, argv[i]) != 0)
res = 2;
}
if(mkdir(argv[i], mode) == -1)
{ {
fprintf(stderr, "%s", "mkdir: ");
perror(argv[i]);
res = 2; res = 2;
continue;
} }
} }
if(mkdir(argv[i], mode) != 0)
res = _mkdir_error(argv[i], 2);
}
return res; return res;
} }
static int _mkdir_error(char * message, int ret)
{
fprintf(stderr, "%s", "mkdir: ");
perror(message);
return ret;
}
static int _mkdir_p(mode_t mode, char * pathname) static int _mkdir_p(mode_t mode, char * pathname)
{ {
char * p; char * p;
char c; char c;
struct stat st;
for(p = pathname; *p != '\0'; p++) for(p = pathname; *p != '\0'; p++)
{ {
@ -46,12 +54,9 @@ static int _mkdir_p(mode_t mode, char * pathname)
continue; continue;
c = *p; c = *p;
*p = '\0'; *p = '\0';
if(mkdir(pathname, mode) == -1) if(!(stat(pathname, &st) == 0 && S_ISDIR(st.st_mode))
{ && mkdir(pathname, mode) == -1)
fprintf(stderr, "%s", "mkdir: "); return _mkdir_error(pathname, 2);
perror(pathname);
return 2;
}
*p = c; *p = c;
} }
return 0; return 0;