Remove entries from the accept list as they are matched so we can determine if any...
authorGlenn L McGrath <bug1@ihug.co.nz>
Sat, 19 Oct 2002 02:18:51 +0000 (02:18 -0000)
committerGlenn L McGrath <bug1@ihug.co.nz>
Sat, 19 Oct 2002 02:18:51 +0000 (02:18 -0000)
archival/libunarchive/filter_accept_list.c
archival/tar.c

index 06b1dd3ddef7551071b75973ae67bfd64794712d..9f92e644003a871cd1b5ef473f8cc639fc833dc3 100644 (file)
@@ -6,10 +6,18 @@
  */
 extern char filter_accept_list(const llist_t *accept_list, const llist_t *reject_list, const char *key)
 {
+       llist_t *accept_old;
+
        while (accept_list) {
                if (fnmatch(accept_list->data, key, 0) == 0) {
+                       /* Remove entry from list */
+                       accept_old->link = accept_list->link;
+                       free(accept_list->data);
+                       free(accept_list);
+                       accept_list = accept_old;
                        return(EXIT_SUCCESS);
                }
+               accept_old = accept_list;
                accept_list = accept_list->link;
        }
        return(EXIT_FAILURE);
index 993478a675e7960d5d4afec3dabfaa18eaef4c18..df110a1494c0ce043211ec6026e8e292201b8bbe 100644 (file)
@@ -717,6 +717,7 @@ int tar_main(int argc, char **argv)
 
 #ifdef CONFIG_FEATURE_TAR_EXCLUDE
                if (tar_handle->reject) {
+                       printf("Reject list\n");
                        tar_handle->filter = filter_accept_reject_list;
                } else
 #endif /* CONFIG_FEATURE_TAR_EXCLUDE */
@@ -762,6 +763,11 @@ int tar_main(int argc, char **argv)
                        while (get_header_tar(tar_handle) == EXIT_SUCCESS);
        }
 
+       /* Skip through list */
+       while (tar_handle->accept) {
+               error_msg_and_die("%s: Not found in archive\n", tar_handle->accept->data);
+               tar_handle->accept = tar_handle->accept->link;
+       }
 #ifdef CONFIG_FEATURE_CLEAN_UP
        if (tar_handle->src_fd != fileno(stdin)) {
                close(tar_handle->src_fd);