diff options
author | Rob Landley | 2006-06-13 14:54:42 +0000 |
---|---|---|
committer | Rob Landley | 2006-06-13 14:54:42 +0000 |
commit | 9a202c9daaac25296129d1b2d63fedd28efe4a0d (patch) | |
tree | 906c371755ccc1abb19955b43cf91f318bf2c891 | |
parent | 1dea55d577641540bfc85f1d969667d89539ef6d (diff) | |
download | busybox-9a202c9daaac25296129d1b2d63fedd28efe4a0d.zip busybox-9a202c9daaac25296129d1b2d63fedd28efe4a0d.tar.gz |
Patch from Denis Vlasenko: unlzma was make files with mode 777. Tweak
everything to do stat() and use xopen3().
-rw-r--r-- | archival/bunzip2.c | 9 | ||||
-rw-r--r-- | archival/gunzip.c | 7 | ||||
-rw-r--r-- | archival/unlzma.c | 7 |
3 files changed, 15 insertions, 8 deletions
diff --git a/archival/bunzip2.c b/archival/bunzip2.c index 1b074c4..09364b4 100644 --- a/archival/bunzip2.c +++ b/archival/bunzip2.c @@ -41,16 +41,21 @@ int bunzip2_main(int argc, char **argv) /* Check that the input is sane. */ if (isatty(src_fd) && (opt & BUNZIP2_OPT_FORCE) == 0) { - bb_error_msg_and_die("compressed data not read from terminal. Use -f to force it."); + bb_error_msg_and_die("Compressed data not read from terminal. Use -f to force it."); } if (filename) { + struct stat stat_buf; char *extension=filename+strlen(filename)-4; if (strcmp(extension, ".bz2") != 0) { bb_error_msg_and_die("Invalid extension"); } + /* TODO: xstat */ + if (stat(filename, &stat_buf) < 0) { + bb_error_msg_and_die("Couldn't stat file %s", filename); + } *extension=0; - dst_fd = bb_xopen(filename, O_WRONLY | O_CREAT); + dst_fd = bb_xopen3(filename, O_WRONLY | O_CREAT, stat_buf.st_mode); } else dst_fd = STDOUT_FILENO; status = uncompressStream(src_fd, dst_fd); if(filename) { diff --git a/archival/gunzip.c b/archival/gunzip.c index 7b93929..35449b0 100644 --- a/archival/gunzip.c +++ b/archival/gunzip.c @@ -137,11 +137,8 @@ int gunzip_main(int argc, char **argv) bb_error_msg_and_die("Invalid extension"); } - /* Open output file */ - dst_fd = bb_xopen(new_path, O_WRONLY | O_CREAT); - - /* Set permissions on the file */ - chmod(new_path, stat_buf.st_mode); + /* Open output file (with correct permissions) */ + dst_fd = bb_xopen3(new_path, O_WRONLY | O_CREAT, stat_buf.st_mode); /* If unzip succeeds remove the old file */ delete_path = old_path; diff --git a/archival/unlzma.c b/archival/unlzma.c index dc85cb2..404da0a 100644 --- a/archival/unlzma.c +++ b/archival/unlzma.c @@ -41,13 +41,18 @@ int unlzma_main(int argc, char **argv) filename = 0; if (filename) { + struct stat stat_buf; char *extension = filename + strlen(filename) - 5; if (strcmp(extension, ".lzma") != 0) { bb_error_msg_and_die("Invalid extension"); } + /* TODO: xstat? */ + if (stat(filename, &stat_buf) < 0) { + bb_error_msg_and_die("Couldn't stat file %s", filename); + } *extension = 0; - dst_fd = bb_xopen(filename, O_WRONLY | O_CREAT); + dst_fd = bb_xopen3(filename, O_WRONLY | O_CREAT, stat_buf.st_mode); } else dst_fd = STDOUT_FILENO; status = unlzma(src_fd, dst_fd); |