summaryrefslogtreecommitdiff
path: root/git/index/base.py
diff options
context:
space:
mode:
authorSebastian Thiel <byronimo@gmail.com>2016-04-14 07:12:57 +0200
committerSebastian Thiel <byronimo@gmail.com>2016-04-14 07:12:57 +0200
commit978eb5bd4751acf9d53c8b6626dc3f7832a20ccf (patch)
treec4dcf0b69d49eaa4dcd1d8bc8e59822405704944 /git/index/base.py
parent9debf6b0aafb6f7781ea9d1383c86939a1aacde3 (diff)
parent6f6713669a8a32af90a73d03a7fa24e6154327f2 (diff)
downloadgitpython-978eb5bd4751acf9d53c8b6626dc3f7832a20ccf.tar.gz
Merge pull request #410 from ppietrasa/master
fix(index): avoid recursing endlessly in add()
Diffstat (limited to 'git/index/base.py')
-rw-r--r--git/index/base.py14
1 files changed, 11 insertions, 3 deletions
diff --git a/git/index/base.py b/git/index/base.py
index f80eb290..3e68f843 100644
--- a/git/index/base.py
+++ b/git/index/base.py
@@ -380,9 +380,17 @@ class IndexFile(LazyMixin, diff.Diffable, Serializable):
# resolve globs if possible
if '?' in path or '*' in path or '[' in path:
- for f in self._iter_expand_paths(glob.glob(abs_path)):
- yield f.replace(rs, '')
- continue
+ resolved_paths = glob.glob(abs_path)
+ # not abs_path in resolved_paths:
+ # a glob() resolving to the same path we are feeding it with
+ # is a glob() that failed to resolve. If we continued calling
+ # ourselves we'd endlessly recurse. If the condition below
+ # evaluates to true then we are likely dealing with a file
+ # whose name contains wildcard characters.
+ if abs_path not in resolved_paths:
+ for f in self._iter_expand_paths(glob.glob(abs_path)):
+ yield f.replace(rs, '')
+ continue
# END glob handling
try:
for root, dirs, files in os.walk(abs_path, onerror=raise_exc):