aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorandersen <andersen@69ca8d6d-28ef-0310-b511-8ec308f3f277>2004-10-13 06:25:52 +0000
committerandersen <andersen@69ca8d6d-28ef-0310-b511-8ec308f3f277>2004-10-13 06:25:52 +0000
commit97646e50dee99cee5782b2f7ce2bde2ba08aaa94 (patch)
tree0f595c0a178264458bdeadab565bb5892f006d97
parent3486e083178d17a482a4a43a1d9dfa9a8eb08657 (diff)
downloadbusybox-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.c2
-rw-r--r--libbb/make_directory.c9
-rw-r--r--miscutils/devfsd.c2
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);