Add missing include files
[oweals/busybox.git] / archival / libunarchive / filter_accept_list.c
index 9f92e644003a871cd1b5ef473f8cc639fc833dc3..e1c4827bf2dc0f858fe0e0fc989e4a6c0b95ffa3 100644 (file)
@@ -1,24 +1,34 @@
+/*
+ *  Copyright (C) 2002 by Glenn McGrath
+ *
+ *  This program is free software; you can redistribute it and/or modify
+ *  it under the terms of the GNU General Public License as published by
+ *  the Free Software Foundation; either version 2 of the License, or
+ *  (at your option) any later version.
+ *
+ *  This program is distributed in the hope that it will be useful,
+ *  but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *  GNU General Public License for more details.
+ *
+ *  You should have received a copy of the GNU General Public License
+ *  along with this program; if not, write to the Free Software
+ *  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ */
+
 #include <fnmatch.h>
 #include <stdlib.h>
+
 #include "unarchive.h"
+
 /*
- * Accept names that are in the accept list
+ * Accept names that are in the accept list, ignoring reject list.
  */
-extern char filter_accept_list(const llist_t *accept_list, const llist_t *reject_list, const char *key)
+extern char filter_accept_list(archive_handle_t *archive_handle)
 {
-       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;
+       if (find_list_entry(archive_handle->accept, archive_handle->file_header->name)) {
+               return(EXIT_SUCCESS);
+       } else {
+               return(EXIT_FAILURE);
        }
-       return(EXIT_FAILURE);
 }