Make certain clients of bb_make_directory default to honoring
the user's umask
This commit is contained in:
parent
9315842242
commit
0e020d1025
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user