diff options
author | andersen <andersen@69ca8d6d-28ef-0310-b511-8ec308f3f277> | 2004-10-13 06:25:52 +0000 |
---|---|---|
committer | andersen <andersen@69ca8d6d-28ef-0310-b511-8ec308f3f277> | 2004-10-13 06:25:52 +0000 |
commit | 97646e50dee99cee5782b2f7ce2bde2ba08aaa94 (patch) | |
tree | 0f595c0a178264458bdeadab565bb5892f006d97 | |
parent | 3486e083178d17a482a4a43a1d9dfa9a8eb08657 (diff) | |
download | busybox-w32-97646e50dee99cee5782b2f7ce2bde2ba08aaa94.tar.gz busybox-w32-97646e50dee99cee5782b2f7ce2bde2ba08aaa94.tar.bz2 busybox-w32-97646e50dee99cee5782b2f7ce2bde2ba08aaa94.zip |
Make certain clients of bb_make_directory default to honoring
the user's umask
git-svn-id: svn://busybox.net/trunk/busybox@9413 69ca8d6d-28ef-0310-b511-8ec308f3f277
-rw-r--r-- | archival/libunarchive/data_extract_all.c | 2 | ||||
-rw-r--r-- | libbb/make_directory.c | 9 | ||||
-rw-r--r-- | miscutils/devfsd.c | 2 |
3 files changed, 10 insertions, 3 deletions
diff --git a/archival/libunarchive/data_extract_all.c b/archival/libunarchive/data_extract_all.c index 52edaa182..d10d665f6 100644 --- a/archival/libunarchive/data_extract_all.c +++ b/archival/libunarchive/data_extract_all.c | |||
@@ -35,7 +35,7 @@ extern void data_extract_all(archive_handle_t *archive_handle) | |||
35 | 35 | ||
36 | if (archive_handle->flags & ARCHIVE_CREATE_LEADING_DIRS) { | 36 | if (archive_handle->flags & ARCHIVE_CREATE_LEADING_DIRS) { |
37 | char *name = bb_xstrdup(file_header->name); | 37 | char *name = bb_xstrdup(file_header->name); |
38 | bb_make_directory (dirname(name), 0777, FILEUTILS_RECUR); | 38 | bb_make_directory (dirname(name), -1, FILEUTILS_RECUR); |
39 | free(name); | 39 | free(name); |
40 | } | 40 | } |
41 | 41 | ||
diff --git a/libbb/make_directory.c b/libbb/make_directory.c index d07ccb93c..d96acf0d9 100644 --- a/libbb/make_directory.c +++ b/libbb/make_directory.c | |||
@@ -49,7 +49,14 @@ int bb_make_directory (char *path, long mode, int flags) | |||
49 | struct stat st; | 49 | struct stat st; |
50 | 50 | ||
51 | mask = umask(0); | 51 | mask = umask(0); |
52 | umask(mask & ~0300); | 52 | if (mode == -1) { |
53 | umask(mask); | ||
54 | mode = (S_IXUSR | S_IXGRP | S_IXOTH | | ||
55 | S_IWUSR | S_IWGRP | S_IWOTH | | ||
56 | S_IRUSR | S_IRGRP | S_IROTH) & ~mask; | ||
57 | } else { | ||
58 | umask(mask & ~0300); | ||
59 | } | ||
53 | 60 | ||
54 | do { | 61 | do { |
55 | c = 0; | 62 | c = 0; |
diff --git a/miscutils/devfsd.c b/miscutils/devfsd.c index c2dde91c6..5e183e61f 100644 --- a/miscutils/devfsd.c +++ b/miscutils/devfsd.c | |||
@@ -1547,7 +1547,7 @@ static int make_dir_tree (const char *path) | |||
1547 | #ifdef CONFIG_DEBUG | 1547 | #ifdef CONFIG_DEBUG |
1548 | msg_logger( NO_DIE, LOG_INFO, "make_dir_tree()\n"); | 1548 | msg_logger( NO_DIE, LOG_INFO, "make_dir_tree()\n"); |
1549 | #endif | 1549 | #endif |
1550 | if (bb_make_directory( dirname((char *)path), S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH ,FILEUTILS_RECUR )==-1) | 1550 | if (bb_make_directory( dirname((char *)path), -1, FILEUTILS_RECUR )==-1) |
1551 | { | 1551 | { |
1552 | #ifdef CONFIG_DEBUG | 1552 | #ifdef CONFIG_DEBUG |
1553 | msg_logger( NO_DIE, LOG_ERR, "make_dir_tree(): %s: %m\n", path); | 1553 | msg_logger( NO_DIE, LOG_ERR, "make_dir_tree(): %s: %m\n", path); |