Make certain clients of bb_make_directory default to honoring

the user's umask
This commit is contained in:
Eric Andersen 2004-10-13 06:25:52 +00:00
parent 9315842242
commit 0e020d1025
3 changed files with 10 additions and 3 deletions

View File

@ -35,7 +35,7 @@ extern void data_extract_all(archive_handle_t *archive_handle)
if (archive_handle->flags & ARCHIVE_CREATE_LEADING_DIRS) { if (archive_handle->flags & ARCHIVE_CREATE_LEADING_DIRS) {
char *name = bb_xstrdup(file_header->name); char *name = bb_xstrdup(file_header->name);
bb_make_directory (dirname(name), 0777, FILEUTILS_RECUR); bb_make_directory (dirname(name), -1, FILEUTILS_RECUR);
free(name); free(name);
} }

View File

@ -49,7 +49,14 @@ int bb_make_directory (char *path, long mode, int flags)
struct stat st; struct stat st;
mask = umask(0); mask = umask(0);
umask(mask & ~0300); if (mode == -1) {
umask(mask);
mode = (S_IXUSR | S_IXGRP | S_IXOTH |
S_IWUSR | S_IWGRP | S_IWOTH |
S_IRUSR | S_IRGRP | S_IROTH) & ~mask;
} else {
umask(mask & ~0300);
}
do { do {
c = 0; c = 0;

View File

@ -1547,7 +1547,7 @@ static int make_dir_tree (const char *path)
#ifdef CONFIG_DEBUG #ifdef CONFIG_DEBUG
msg_logger( NO_DIE, LOG_INFO, "make_dir_tree()\n"); msg_logger( NO_DIE, LOG_INFO, "make_dir_tree()\n");
#endif #endif
if (bb_make_directory( dirname((char *)path), S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH ,FILEUTILS_RECUR )==-1) if (bb_make_directory( dirname((char *)path), -1, FILEUTILS_RECUR )==-1)
{ {
#ifdef CONFIG_DEBUG #ifdef CONFIG_DEBUG
msg_logger( NO_DIE, LOG_ERR, "make_dir_tree(): %s: %m\n", path); msg_logger( NO_DIE, LOG_ERR, "make_dir_tree(): %s: %m\n", path);