summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorMartin v. Löwis <martin@v.loewis.de>2001-06-06 06:24:38 (GMT)
committerMartin v. Löwis <martin@v.loewis.de>2001-06-06 06:24:38 (GMT)
commitb5d4d2a7d53f8c2926fd3004aeba0b8b38a3d111 (patch)
treef0a72d769fd1ecb88bbd37f5d89be2413479d140 /Lib
parent3d10b34b9c027d1e1c5613a4b1d80be4d31fb47a (diff)
downloadcpython-b5d4d2a7d53f8c2926fd3004aeba0b8b38a3d111.zip
cpython-b5d4d2a7d53f8c2926fd3004aeba0b8b38a3d111.tar.gz
cpython-b5d4d2a7d53f8c2926fd3004aeba0b8b38a3d111.tar.bz2
Patch #409973: Speedup glob.glob, add fnmatch.filter.
Diffstat (limited to 'Lib')
-rw-r--r--Lib/fnmatch.py20
-rw-r--r--Lib/glob.py13
2 files changed, 26 insertions, 7 deletions
diff --git a/Lib/fnmatch.py b/Lib/fnmatch.py
index 182a9ef..da0bb34 100644
--- a/Lib/fnmatch.py
+++ b/Lib/fnmatch.py
@@ -37,6 +37,26 @@ def fnmatch(name, pat):
pat = os.path.normcase(pat)
return fnmatchcase(name, pat)
+def filter(names, pat):
+ """Return the subset of the list NAMES that match PAT"""
+ import os,posixpath
+ result=[]
+ pat=os.path.normcase(pat)
+ if not _cache.has_key(pat):
+ res = translate(pat)
+ _cache[pat] = re.compile(res)
+ match=_cache[pat].match
+ if os.path is posixpath:
+ # normcase on posix is NOP. Optimize it away from the loop.
+ for name in names:
+ if match(name):
+ result.append(name)
+ else:
+ for name in names:
+ if match(os.path.normcase(name)):
+ result.append(name)
+ return result
+
def fnmatchcase(name, pat):
"""Test whether FILENAME matches PATTERN, including case.
diff --git a/Lib/glob.py b/Lib/glob.py
index eeb6bdd..d5e508a 100644
--- a/Lib/glob.py
+++ b/Lib/glob.py
@@ -18,7 +18,9 @@ def glob(pathname):
else:
return []
dirname, basename = os.path.split(pathname)
- if has_magic(dirname):
+ if not dirname:
+ return glob1(os.curdir, basename)
+ elif has_magic(dirname):
list = glob(dirname)
else:
list = [dirname]
@@ -43,12 +45,9 @@ def glob1(dirname, pattern):
names = os.listdir(dirname)
except os.error:
return []
- result = []
- for name in names:
- if name[0] != '.' or pattern[0] == '.':
- if fnmatch.fnmatch(name, pattern):
- result.append(name)
- return result
+ if pattern[0]!='.':
+ names=filter(lambda x: x[0]!='.',names)
+ return fnmatch.filter(names,pattern)
magic_check = re.compile('[*?[]')