mirror of https://github.com/python/cpython
Merged revisions 74493 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r74493 | tarek.ziade | 2009-08-17 23:28:34 +0200 (Mon, 17 Aug 2009) | 1 line fixed how fnmatch.translate is used (since it has changed in r74475 for #6665). Now the code is not harcoding the usage of $ anymore ........
This commit is contained in:
parent
8c6b0a5bcb
commit
74c23ac08d
|
@ -312,7 +312,9 @@ def translate_pattern(pattern, anchor=1, prefix=None, is_regex=0):
|
||||||
pattern_re = ''
|
pattern_re = ''
|
||||||
|
|
||||||
if prefix is not None:
|
if prefix is not None:
|
||||||
prefix_re = (glob_to_re(prefix))[0:-1] # ditch trailing $
|
# ditch end of pattern character
|
||||||
|
empty_pattern = glob_to_re('')
|
||||||
|
prefix_re = (glob_to_re(prefix))[:-len(empty_pattern)]
|
||||||
pattern_re = "^" + os.path.join(prefix_re, ".*" + pattern_re)
|
pattern_re = "^" + os.path.join(prefix_re, ".*" + pattern_re)
|
||||||
else: # no prefix -- respect anchor flag
|
else: # no prefix -- respect anchor flag
|
||||||
if anchor:
|
if anchor:
|
||||||
|
|
|
@ -6,15 +6,15 @@ class FileListTestCase(unittest.TestCase):
|
||||||
|
|
||||||
def test_glob_to_re(self):
|
def test_glob_to_re(self):
|
||||||
# simple cases
|
# simple cases
|
||||||
self.assertEquals(glob_to_re('foo*'), 'foo[^/]*$')
|
self.assertEquals(glob_to_re('foo*'), 'foo[^/]*\\Z(?ms)')
|
||||||
self.assertEquals(glob_to_re('foo?'), 'foo[^/]$')
|
self.assertEquals(glob_to_re('foo?'), 'foo[^/]\\Z(?ms)')
|
||||||
self.assertEquals(glob_to_re('foo??'), 'foo[^/][^/]$')
|
self.assertEquals(glob_to_re('foo??'), 'foo[^/][^/]\\Z(?ms)')
|
||||||
|
|
||||||
# special cases
|
# special cases
|
||||||
self.assertEquals(glob_to_re(r'foo\\*'), r'foo\\\\[^/]*$')
|
self.assertEquals(glob_to_re(r'foo\\*'), r'foo\\\\[^/]*\Z(?ms)')
|
||||||
self.assertEquals(glob_to_re(r'foo\\\*'), r'foo\\\\\\[^/]*$')
|
self.assertEquals(glob_to_re(r'foo\\\*'), r'foo\\\\\\[^/]*\Z(?ms)')
|
||||||
self.assertEquals(glob_to_re('foo????'), r'foo[^/][^/][^/][^/]$')
|
self.assertEquals(glob_to_re('foo????'), r'foo[^/][^/][^/][^/]\Z(?ms)')
|
||||||
self.assertEquals(glob_to_re(r'foo\\??'), r'foo\\\\[^/][^/]$')
|
self.assertEquals(glob_to_re(r'foo\\??'), r'foo\\\\[^/][^/]\Z(?ms)')
|
||||||
|
|
||||||
def test_suite():
|
def test_suite():
|
||||||
return unittest.makeSuite(FileListTestCase)
|
return unittest.makeSuite(FileListTestCase)
|
||||||
|
|
Loading…
Reference in New Issue