Blame SOURCES/tar-1.17-wildcards.patch

a4d85a
diff --git a/doc/tar.texi b/doc/tar.texi
a4d85a
index db8f986..d70d113 100644
a4d85a
--- a/doc/tar.texi
a4d85a
+++ b/doc/tar.texi
a4d85a
@@ -7597,7 +7597,7 @@ The following table summarizes pattern-matching default values:
a4d85a
 
a4d85a
 @multitable @columnfractions .3 .7
a4d85a
 @headitem Members @tab Default settings
a4d85a
-@item Inclusion @tab @option{--no-wildcards --anchored --no-wildcards-match-slash}
a4d85a
+@item Inclusion @tab @option{--wildcards --anchored --wildcards-match-slash}
a4d85a
 @item Exclusion @tab @option{--wildcards --no-anchored --wildcards-match-slash}
a4d85a
 @end multitable
a4d85a
 
a4d85a
@@ -12038,6 +12038,9 @@ version of this document is available at
a4d85a
 @table @asis
a4d85a
 @item Use of globbing patterns when listing and extracting.
a4d85a
 
a4d85a
+Note: Following is true for original unpatched GNU tar.
a4d85a
+For compatibility reasons, the old behavior was preserved.
a4d85a
+
a4d85a
 Previous versions of GNU tar assumed shell-style globbing when
a4d85a
 extracting from or listing an archive.  For example:
a4d85a
 
a4d85a
diff --git a/src/names.c b/src/names.c
a4d85a
index ba4d509..3911f8c 100644
a4d85a
--- a/src/names.c
a4d85a
+++ b/src/names.c
a4d85a
@@ -966,10 +966,7 @@ collect_and_sort_names (void)
a4d85a
 
a4d85a
       if (name->found_count || name->directory)
a4d85a
 	continue;
a4d85a
-      if (name->matching_flags & EXCLUDE_WILDCARDS)
a4d85a
-	/* NOTE: EXCLUDE_ANCHORED is not relevant here */
a4d85a
-	/* FIXME: just skip regexps for now */
a4d85a
-	continue;
a4d85a
+
a4d85a
       chdir_do (name->change_dir);
a4d85a
 
a4d85a
       if (name->name[0] == 0)
a4d85a
diff --git a/src/tar.c b/src/tar.c
a4d85a
index 928cfdd..22d3db1 100644
a4d85a
--- a/src/tar.c
a4d85a
+++ b/src/tar.c
a4d85a
@@ -722,7 +722,7 @@ static struct argp_option options[] = {
a4d85a
   {"no-ignore-case", NO_IGNORE_CASE_OPTION, 0, 0,
a4d85a
    N_("case sensitive matching (default)"), GRID+1 },
a4d85a
   {"wildcards", WILDCARDS_OPTION, 0, 0,
a4d85a
-   N_("use wildcards (default for exclusion)"), GRID+1 },
a4d85a
+   N_("use wildcards (default)"), GRID+1 },
a4d85a
   {"no-wildcards", NO_WILDCARDS_OPTION, 0, 0,
a4d85a
    N_("verbatim string matching"), GRID+1 },
a4d85a
   {"no-wildcards-match-slash", NO_WILDCARDS_MATCH_SLASH_OPTION, 0, 0,
a4d85a
@@ -815,8 +815,7 @@ ARGMATCH_VERIFY (atime_preserve_args, atime_preserve_types);
a4d85a
 /* Wildcard matching settings */
a4d85a
 enum wildcards
a4d85a
   {
a4d85a
-    default_wildcards, /* For exclusion == enable_wildcards,
a4d85a
-			  for inclusion == disable_wildcards */
a4d85a
+    default_wildcards, /* enable_wildcards */
a4d85a
     disable_wildcards,
a4d85a
     enable_wildcards
a4d85a
   };
a4d85a
@@ -847,7 +846,7 @@ struct tar_args        /* Variables used during option parsing */
a4d85a
   | recursion_option)
a4d85a
 
a4d85a
 #define MAKE_INCL_OPTIONS(args) \
a4d85a
- ((((args)->wildcards == enable_wildcards) ? EXCLUDE_WILDCARDS : 0) \
a4d85a
+ ((((args)->wildcards != disable_wildcards) ? EXCLUDE_WILDCARDS : 0) \
a4d85a
   | (args)->include_anchored \
a4d85a
   | (args)->matching_flags \
a4d85a
   | recursion_option)
a4d85a
@@ -2347,7 +2346,7 @@ decode_options (int argc, char **argv)
a4d85a
 
a4d85a
   /* Warn about implicit use of the wildcards in command line arguments.
a4d85a
      See TODO */
a4d85a
-  warn_regex_usage = args.wildcards == default_wildcards;
a4d85a
+  warn_regex_usage = 0; /* args.wildcards == default_wildcards; */
a4d85a
 
a4d85a
   /* Derive option values and check option consistency.  */
a4d85a
 
a4d85a
diff --git a/tests/exclude01.at b/tests/exclude01.at
a4d85a
index 778a7fc..bd65ae0 100644
a4d85a
--- a/tests/exclude01.at
a4d85a
+++ b/tests/exclude01.at
a4d85a
@@ -59,6 +59,7 @@ testdir/dir2/file2
a4d85a
 testdir/dir3/
a4d85a
 NEXT
a4d85a
 testdir/dir1/*
a4d85a
+testdir/dir1/file1
a4d85a
 NEXT
a4d85a
 testdir/dir1/*
a4d85a
 NEXT