diff options
author | Paul Eggert <eggert@cs.ucla.edu> | 2006-01-02 06:37:36 +0000 |
---|---|---|
committer | Paul Eggert <eggert@cs.ucla.edu> | 2006-01-02 06:37:36 +0000 |
commit | 51050b62c890b9e988335d6fa444c252392a84db (patch) | |
tree | 143d619b1c9532135eafa79afd5296dc475760e7 | |
parent | 4aff81e69a0c3ce376e331a088f0839335f8400d (diff) | |
download | coreutils-51050b62c890b9e988335d6fa444c252392a84db.tar.xz |
Include lchmod.h.
(usage): Clarify -m's operation.
(main): Use lchmod rather than chmod. Don't use lchmod unless the
new mode contains bits outside the 777 range.
-rw-r--r-- | src/mkdir.c | 22 |
1 files changed, 7 insertions, 15 deletions
diff --git a/src/mkdir.c b/src/mkdir.c index c3635a58b..dd76d6a5e 100644 --- a/src/mkdir.c +++ b/src/mkdir.c @@ -1,5 +1,5 @@ /* mkdir -- make directories - Copyright (C) 90, 1995-2002, 2004, 2005 Free Software Foundation, Inc. + Copyright (C) 90, 1995-2002, 2004, 2005, 2006 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 @@ -23,9 +23,9 @@ #include <sys/types.h> #include "system.h" -#include "chmod-safer.h" #include "dirname.h" #include "error.h" +#include "lchmod.h" #include "mkdir-p.h" #include "modechange.h" #include "quote.h" @@ -65,7 +65,7 @@ Create the DIRECTORY(ies), if they do not already exist.\n\ Mandatory arguments to long options are mandatory for short options too.\n\ "), stdout); fputs (_("\ - -m, --mode=MODE set permission mode (as in chmod), not rwxrwxrwx - umask\n\ + -m, --mode=MODE set file mode (as in chmod), not a=rwx - umask\n\ -p, --parents no error if existing, make parent directories as needed\n\ -v, --verbose print a message for each created directory\n\ "), stdout); @@ -80,7 +80,6 @@ int main (int argc, char **argv) { mode_t newmode; - mode_t tmp_mode; mode_t parent_mode IF_LINT (= 0); const char *specified_mode = NULL; const char *verbose_fmt_string = NULL; @@ -144,11 +143,6 @@ main (int argc, char **argv) umask (umask_value); } - /* This is the mode we'll use in the mknod or mkfifo call. - If it doesn't include S_IRUSR, use S_IRUSR so the final - open-for-fchmod will succeed. */ - tmp_mode = (newmode & S_IRUSR) ? newmode : S_IRUSR; - for (; optind < argc; ++optind) { char *dir = argv[optind]; @@ -168,7 +162,7 @@ main (int argc, char **argv) } else { - ok = (mkdir (dir, tmp_mode) == 0); + ok = (mkdir (dir, newmode) == 0); if (! ok) error (0, errno, _("cannot create directory %s"), quote (dir)); @@ -177,15 +171,13 @@ main (int argc, char **argv) /* mkdir(2) is required to honor only the file permission bits. In particular, it needn't do anything about `special' bits, - so if any were set in newmode, apply them with chmod. - This extra step is necessary in some cases when the containing - directory has a default ACL. */ + so if any were set in newmode, apply them with lchmod. */ /* Set the permissions only if this directory has just been created. */ - if (ok && specified_mode - && chmod_safer (dir, newmode, 0, S_IFDIR) != 0) + if (ok && specified_mode && (newmode & ~S_IRWXUGO) + && lchmod (dir, newmode) != 0) { error (0, errno, _("cannot set permissions of directory %s"), quote (dir)); |