summaryrefslogtreecommitdiff
path: root/archival/bunzip2.c
diff options
context:
space:
mode:
authorDenis Vlasenko2006-09-03 14:23:29 +0000
committerDenis Vlasenko2006-09-03 14:23:29 +0000
commit22dca23d52c836e40c79cb4042b867fdc06f6ca3 (patch)
treea9f7e6c318e749875288358c963d53c25fab681a /archival/bunzip2.c
parent314908da9e156e3100275598dde6848da038d65d (diff)
downloadbusybox-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.c13
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);
}