archival: added O_TRUNC so that when we overwrite files on unpack,

we truncate them. Also spotted & fixed hard to trigger bug
          with extension handling.
This commit is contained in:
Denis Vlasenko 2006-09-03 14:23:29 +00:00
parent 314908da9e
commit 22dca23d52
5 changed files with 19 additions and 13 deletions

View File

@ -41,17 +41,20 @@ int bunzip2_main(int argc, char **argv)
if (filename) { if (filename) {
struct stat stat_buf; struct stat stat_buf;
char *extension=filename+strlen(filename)-4; /* extension = filename+strlen(filename)-4 is buggy:
if (strcmp(extension, ".bz2") != 0) { * strlen may be less than 4 */
char *extension = strrchr(filename, '.');
if (!extension || strcmp(extension, ".bz2") != 0) {
bb_error_msg_and_die("Invalid extension"); bb_error_msg_and_die("Invalid extension");
} }
xstat(filename, &stat_buf); xstat(filename, &stat_buf);
*extension=0; *extension = '\0';
dst_fd = xopen3(filename, O_WRONLY | O_CREAT, stat_buf.st_mode); dst_fd = xopen3(filename, O_WRONLY | O_CREAT | O_TRUNC,
stat_buf.st_mode);
} else dst_fd = STDOUT_FILENO; } else dst_fd = STDOUT_FILENO;
status = uncompressStream(src_fd, dst_fd); status = uncompressStream(src_fd, dst_fd);
if(filename) { if(filename) {
if (!status) filename[strlen(filename)]='.'; if (!status) filename[strlen(filename)] = '.';
if (unlink(filename) < 0) { if (unlink(filename) < 0) {
bb_error_msg_and_die("Couldn't remove %s", filename); bb_error_msg_and_die("Couldn't remove %s", filename);
} }

View File

@ -98,7 +98,8 @@ int gunzip_main(int argc, char **argv)
} }
/* Open output file (with correct permissions) */ /* Open output file (with correct permissions) */
dst_fd = xopen3(new_path, O_WRONLY | O_CREAT, stat_buf.st_mode); dst_fd = xopen3(new_path, O_WRONLY | O_CREAT | O_TRUNC,
stat_buf.st_mode);
/* If unzip succeeds remove the old file */ /* If unzip succeeds remove the old file */
delete_path = old_path; delete_path = old_path;

View File

@ -55,7 +55,8 @@ int uncompress_main(int argc, char **argv)
/* Open output file */ /* Open output file */
xstat(compressed_file, &stat_buf); xstat(compressed_file, &stat_buf);
dst_fd = xopen3(uncompressed_file, O_WRONLY | O_CREAT, dst_fd = xopen3(uncompressed_file,
O_WRONLY | O_CREAT | O_TRUNC,
stat_buf.st_mode); stat_buf.st_mode);
/* If unzip succeeds remove the old file */ /* If unzip succeeds remove the old file */

View File

@ -37,14 +37,15 @@ int unlzma_main(int argc, char **argv)
if (filename) { if (filename) {
struct stat stat_buf; struct stat stat_buf;
char *extension = filename + strlen(filename) - 5; /* bug: char *extension = filename + strlen(filename) - 5; */
char *extension = strrchr(filename, '.');
if (strcmp(extension, ".lzma") != 0) { if (!extension || strcmp(extension, ".lzma") != 0) {
bb_error_msg_and_die("Invalid extension"); bb_error_msg_and_die("Invalid extension");
} }
xstat(filename, &stat_buf); xstat(filename, &stat_buf);
*extension = 0; *extension = '\0';
dst_fd = xopen3(filename, O_WRONLY | O_CREAT, stat_buf.st_mode); dst_fd = xopen3(filename, O_WRONLY | O_CREAT | O_TRUNC,
stat_buf.st_mode);
} else } else
dst_fd = STDOUT_FILENO; dst_fd = STDOUT_FILENO;
status = unlzma(src_fd, dst_fd); status = unlzma(src_fd, dst_fd);

View File

@ -333,7 +333,7 @@ int unzip_main(int argc, char **argv)
overwrite = o_always; overwrite = o_always;
case 'y': /* Open file and fall into unzip */ case 'y': /* Open file and fall into unzip */
unzip_create_leading_dirs(dst_fn); unzip_create_leading_dirs(dst_fn);
dst_fd = xopen3(dst_fn, O_WRONLY | O_CREAT, 0777); dst_fd = xopen3(dst_fn, O_WRONLY | O_CREAT | O_TRUNC, 0777);
case -1: /* Unzip */ case -1: /* Unzip */
if (verbosity == v_normal) { if (verbosity == v_normal) {
printf(" inflating: %s\n", dst_fn); printf(" inflating: %s\n", dst_fn);