X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fmkdir.c;h=8073dc8da402da6e21d7bc59a1e732fefdd782ac;hb=fe18f20f2ac58f3fda945a633eccb85acc83e3e1;hp=e68ccb17c7072923aecf68102e0edc2ca3b6814c;hpb=d87c39464604e74f580c7fae835be31a4c125c36;p=gnulib.git diff --git a/lib/mkdir.c b/lib/mkdir.c index e68ccb17c..8073dc8da 100644 --- a/lib/mkdir.c +++ b/lib/mkdir.c @@ -1,10 +1,12 @@ -/* mkrmdir.c -- BSD compatible directory functions for System V - Copyright (C) 1988, 1990 Free Software Foundation, Inc. +/* On some systems, mkdir ("foo/", 0700) fails because of the trailing + slash. On those systems, this wrapper removes the trailing slash. - This program is free software; you can redistribute it and/or modify + Copyright (C) 2001, 2003, 2006, 2008 Free Software Foundation, Inc. + + This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by - the Free Software Foundation; either version 2, or (at your option) - any later version. + the Free Software Foundation; either version 3 of the License, or + (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -12,114 +14,57 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ + along with this program. If not, see . */ + +/* written by Jim Meyering */ +#include + +/* Specification. */ #include #include -#include -#ifndef STDC_HEADERS -extern int errno; -#endif -/* mkdir and rmdir adapted from GNU tar. */ +#include +#include +#include -/* Make directory DPATH, with permission mode DMODE. +#include "dirname.h" +#include "xalloc.h" - Written by Robert Rother, Mariah Corporation, August 1985 - (sdcsvax!rmr or rmr@uscd). If you want it, it's yours. +/* Disable the definition of mkdir to rpl_mkdir (from the + substitute) in this file. Otherwise, we'd get an endless recursion. */ +#undef mkdir - Severely hacked over by John Gilmore to make a 4.2BSD compatible - subroutine. 11Mar86; hoptoad!gnu +/* mingw's _mkdir() function has 1 argument, but we pass 2 arguments. + Additionally, it declares _mkdir (and depending on compile flags, an + alias mkdir), only in the nonstandard io.h. */ +#if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__ +# define mkdir(name,mode) _mkdir (name) +#endif - Modified by rmtodd@uokmax 6-28-87 -- when making an already existing dir, - subroutine didn't return EEXIST. It does now. */ +/* This function is required at least for NetBSD 1.5.2. */ int -mkdir (dpath, dmode) - char *dpath; - int dmode; +rpl_mkdir (char const *dir, mode_t mode) { - int cpid, status; - struct stat statbuf; + int ret_val; + char *tmp_dir; + size_t len = strlen (dir); - if (stat (dpath, &statbuf) == 0) + if (len && dir[len - 1] == '/') { - errno = EEXIST; /* stat worked, so it already exists. */ - return -1; + tmp_dir = xstrdup (dir); + strip_trailing_slashes (tmp_dir); } - - /* If stat fails for a reason other than non-existence, return error. */ - if (errno != ENOENT) - return -1; - - cpid = fork (); - switch (cpid) + else { - case -1: /* Cannot fork. */ - return -1; /* errno is set already. */ - - case 0: /* Child process. */ - /* Cheap hack to set mode of new directory. Since this child - process is going away anyway, we zap its umask. - This won't suffice to set SUID, SGID, etc. on this - directory, so the parent process calls chmod afterward. */ - status = umask (0); /* Get current umask. */ - umask (status | (0777 & ~dmode)); /* Set for mkdir. */ - execl ("/bin/mkdir", "mkdir", dpath, (char *) 0); - _exit (1); - - default: /* Parent process. */ - while (wait (&status) != cpid) /* Wait for kid to finish. */ - /* Do nothing. */ ; - - if (status & 0xFFFF) - { - errno = EIO; /* /bin/mkdir failed. */ - return -1; - } - return chmod (dpath, dmode); + tmp_dir = (char *) dir; } -} -/* Remove directory DPATH. - Return 0 if successful, -1 if not. */ + ret_val = mkdir (tmp_dir, mode); -int -rmdir (dpath) - char *dpath; -{ - int cpid, status; - struct stat statbuf; - - if (stat (dpath, &statbuf) != 0) - return -1; /* stat set errno. */ - - if ((statbuf.st_mode & S_IFMT) != S_IFDIR) - { - errno = ENOTDIR; - return -1; - } + if (tmp_dir != dir) + free (tmp_dir); - cpid = fork (); - switch (cpid) - { - case -1: /* Cannot fork. */ - return -1; /* errno is set already. */ - - case 0: /* Child process. */ - execl ("/bin/rmdir", "rmdir", dpath, (char *) 0); - _exit (1); - - default: /* Parent process. */ - while (wait (&status) != cpid) /* Wait for kid to finish. */ - /* Do nothing. */ ; - - if (status & 0xFFFF) - { - errno = EIO; /* /bin/rmdir failed. */ - return -1; - } - return 0; - } + return ret_val; }