1
0
Fork 0
mirror of https://github.com/borgbackup/borg.git synced 2025-01-03 05:35:58 +00:00

Merge pull request #2575 from edgimar/master

patterns: don't recurse with ! / --exclude for pf:, fixes #2509
This commit is contained in:
TW 2017-06-03 21:47:11 +02:00 committed by GitHub
commit a2d08e3186

View file

@ -150,9 +150,8 @@ def match(self, path):
if value is not non_existent:
# we have a full path match!
# TODO: get from pattern; don't hard-code
self.recurse_dir = True
return value
self.recurse_dir = command_recurses_dir(value)
return self.is_include_cmd[value]
# this is the slow way, if we have many patterns in self._items:
for (pattern, cmd) in self._items:
@ -325,6 +324,11 @@ class IECommand(Enum):
ExcludeNoRecurse = 5
def command_recurses_dir(cmd):
# TODO?: raise error or return None if *cmd* is RootPath or PatternStyle
return cmd not in [IECommand.ExcludeNoRecurse]
def get_pattern_class(prefix):
try:
return _PATTERN_CLASS_BY_PREFIX[prefix]
@ -386,7 +390,7 @@ def parse_inclexcl_command(cmd_line_str, fallback=ShellPattern):
raise argparse.ArgumentTypeError("Invalid pattern style: {}".format(remainder_str))
else:
# determine recurse_dir based on command type
recurse_dir = cmd not in [IECommand.ExcludeNoRecurse]
recurse_dir = command_recurses_dir(cmd)
val = parse_pattern(remainder_str, fallback, recurse_dir)
return CmdTuple(val, cmd)