diff options
author | Denis Vlasenko | 2006-09-03 14:23:29 +0000 |
---|---|---|
committer | Denis Vlasenko | 2006-09-03 14:23:29 +0000 |
commit | 22dca23d52c836e40c79cb4042b867fdc06f6ca3 (patch) | |
tree | a9f7e6c318e749875288358c963d53c25fab681a /archival/bunzip2.c | |
parent | 314908da9e156e3100275598dde6848da038d65d (diff) | |
download | busybox-22dca23d52c836e40c79cb4042b867fdc06f6ca3.zip busybox-22dca23d52c836e40c79cb4042b867fdc06f6ca3.tar.gz |
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.
Diffstat (limited to 'archival/bunzip2.c')
-rw-r--r-- | archival/bunzip2.c | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/archival/bunzip2.c b/archival/bunzip2.c index a970aeb..9810e02 100644 --- a/archival/bunzip2.c +++ b/archival/bunzip2.c @@ -41,17 +41,20 @@ int bunzip2_main(int argc, char **argv) if (filename) { struct stat stat_buf; - char *extension=filename+strlen(filename)-4; - if (strcmp(extension, ".bz2") != 0) { + /* extension = filename+strlen(filename)-4 is buggy: + * strlen may be less than 4 */ + char *extension = strrchr(filename, '.'); + if (!extension || strcmp(extension, ".bz2") != 0) { bb_error_msg_and_die("Invalid extension"); } xstat(filename, &stat_buf); - *extension=0; - dst_fd = xopen3(filename, O_WRONLY | O_CREAT, stat_buf.st_mode); + *extension = '\0'; + dst_fd = xopen3(filename, O_WRONLY | O_CREAT | O_TRUNC, + stat_buf.st_mode); } else dst_fd = STDOUT_FILENO; status = uncompressStream(src_fd, dst_fd); if(filename) { - if (!status) filename[strlen(filename)]='.'; + if (!status) filename[strlen(filename)] = '.'; if (unlink(filename) < 0) { bb_error_msg_and_die("Couldn't remove %s", filename); } |