diff options
author | bug1 <bug1@69ca8d6d-28ef-0310-b511-8ec308f3f277> | 2001-07-14 08:49:53 +0000 |
---|---|---|
committer | bug1 <bug1@69ca8d6d-28ef-0310-b511-8ec308f3f277> | 2001-07-14 08:49:53 +0000 |
commit | 573b51bdf62e5dfa02b38ebb89059e2c7e1739fb (patch) | |
tree | fe1823623d327a9954d6c09e57c9d42f4fb575b1 /archival/cpio.c | |
parent | c9d8d565e8c924528af3c682491f0b0963b5c2e0 (diff) | |
download | busybox-w32-573b51bdf62e5dfa02b38ebb89059e2c7e1739fb.tar.gz busybox-w32-573b51bdf62e5dfa02b38ebb89059e2c7e1739fb.tar.bz2 busybox-w32-573b51bdf62e5dfa02b38ebb89059e2c7e1739fb.zip |
Allow the unarchive() extract_list variable to be NULL, meaning extract all
git-svn-id: svn://busybox.net/trunk/busybox@3097 69ca8d6d-28ef-0310-b511-8ec308f3f277
Diffstat (limited to 'archival/cpio.c')
-rw-r--r-- | archival/cpio.c | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/archival/cpio.c b/archival/cpio.c index 12a4340bd..7f68715eb 100644 --- a/archival/cpio.c +++ b/archival/cpio.c | |||
@@ -68,25 +68,28 @@ extern int cpio_main(int argc, char **argv) | |||
68 | } | 68 | } |
69 | } | 69 | } |
70 | 70 | ||
71 | if (extract_function & extract_all_to_fs && extract_function & extract_list) { | 71 | if ((extract_function & extract_all_to_fs) && (extract_function & extract_list)) { |
72 | extract_function ^= extract_all_to_fs; /* If specify t, don't extract*/ | 72 | extract_function ^= extract_all_to_fs; /* If specify t, don't extract*/ |
73 | } | 73 | } |
74 | 74 | ||
75 | if (extract_function & extract_all_to_fs && extract_function & extract_verbose_list) { /* The meaning of v changes on extract */ | 75 | if ((extract_function & extract_all_to_fs) && (extract_function & extract_verbose_list)) { |
76 | /* The meaning of v changes on extract */ | ||
76 | extract_function ^= extract_verbose_list; | 77 | extract_function ^= extract_verbose_list; |
77 | extract_function |= extract_list; | 78 | extract_function |= extract_list; |
78 | } | 79 | } |
79 | 80 | ||
80 | extract_names = malloc(4); | ||
81 | while (optind < argc) { | 81 | while (optind < argc) { |
82 | extract_names = xrealloc(extract_names, sizeof(char *) * (num_of_entries + 2)); | ||
83 | extract_names[num_of_entries] = xstrdup(argv[optind]); | ||
82 | num_of_entries++; | 84 | num_of_entries++; |
83 | *extract_names = realloc(*extract_names, num_of_entries); | 85 | extract_names[num_of_entries] = NULL; |
84 | extract_names[num_of_entries - 1] = xstrdup(argv[optind]); | ||
85 | optind++; | 86 | optind++; |
86 | } | 87 | } |
87 | 88 | ||
88 | unarchive(src_stream, stdout, &get_header_cpio, extract_function, "./", extract_names); | 89 | unarchive(src_stream, stdout, &get_header_cpio, extract_function, "./", extract_names); |
89 | if (oldmask) umask(oldmask); /* Restore umask if we changed it */ | 90 | if (oldmask) { |
91 | umask(oldmask); /* Restore umask if we changed it */ | ||
92 | } | ||
90 | return EXIT_SUCCESS; | 93 | return EXIT_SUCCESS; |
91 | } | 94 | } |
92 | 95 | ||