summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Changelog2
-rw-r--r--archival/tar.c9
-rw-r--r--tar.c9
3 files changed, 14 insertions, 6 deletions
diff --git a/Changelog b/Changelog
index c34a7e4..6017ccb 100644
--- a/Changelog
+++ b/Changelog
@@ -20,6 +20,8 @@
-- Fix sed s/[/]// handling (closes: #1208).
-- Fix `-/bin/sh' invocation (closes: #1209).
-- Fix ash exec (noted by Arne Bernin).
+ -- Fix tar segfault when include list is empty and exclude list is
+ not.
* Magick
-- made init run inittab command's in the order they show up
in the inittab file (FIFO instead of LIFO).
diff --git a/archival/tar.c b/archival/tar.c
index cd56339..ea0247e 100644
--- a/archival/tar.c
+++ b/archival/tar.c
@@ -528,7 +528,10 @@ char **merge_list(char **include_list, char **exclude_list)
int new_include_count = 0;
int include_count = 0;
int exclude_count;
-
+
+ if (include_list == NULL)
+ return exclude_list;
+
while (include_list[include_count] != NULL) {
int found = FALSE;
exclude_count = 0;
@@ -684,8 +687,8 @@ int tar_main(int argc, char **argv)
#ifdef BB_FEATURE_TAR_EXCLUDE
/* Remove excluded files from the include list */
if (exclude_list != NULL) {
- /* If both an exclude and include file list was present then
- * its an exclude from include list only, if not its really an
+ /* If both an exclude and include file list were present then
+ * it's an exclude from include list only, if not it's really an
* exclude list (and a poor choice of variable names) */
if (include_list == NULL) {
extract_function |= extract_exclude_list;
diff --git a/tar.c b/tar.c
index cd56339..ea0247e 100644
--- a/tar.c
+++ b/tar.c
@@ -528,7 +528,10 @@ char **merge_list(char **include_list, char **exclude_list)
int new_include_count = 0;
int include_count = 0;
int exclude_count;
-
+
+ if (include_list == NULL)
+ return exclude_list;
+
while (include_list[include_count] != NULL) {
int found = FALSE;
exclude_count = 0;
@@ -684,8 +687,8 @@ int tar_main(int argc, char **argv)
#ifdef BB_FEATURE_TAR_EXCLUDE
/* Remove excluded files from the include list */
if (exclude_list != NULL) {
- /* If both an exclude and include file list was present then
- * its an exclude from include list only, if not its really an
+ /* If both an exclude and include file list were present then
+ * it's an exclude from include list only, if not it's really an
* exclude list (and a poor choice of variable names) */
if (include_list == NULL) {
extract_function |= extract_exclude_list;