diff options
author | Georg Brandl <georg@python.org> | 2007-03-07 08:31:51 +0000 |
---|---|---|
committer | Georg Brandl <georg@python.org> | 2007-03-07 08:31:51 +0000 |
commit | 71ff64674375b355c9449f8b511b49756d880e48 (patch) | |
tree | 5e38f0cbe2602c4fe59a935e830ef432ee51c785 | |
parent | 172e7257f65e5d37974aacf0c467e76a321ddf2c (diff) | |
download | cpython-git-71ff64674375b355c9449f8b511b49756d880e48.tar.gz |
Patch #1001604: glob.glob() now returns unicode filenames if it was
given a unicode argument and os.listdir() returns unicode filenames.
-rw-r--r-- | Lib/glob.py | 11 | ||||
-rw-r--r-- | Lib/test/test_glob.py | 10 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
3 files changed, 20 insertions, 4 deletions
diff --git a/Lib/glob.py b/Lib/glob.py index 95656cc1a6..a92b11f431 100644 --- a/Lib/glob.py +++ b/Lib/glob.py @@ -1,8 +1,9 @@ """Filename globbing utility.""" +import sys import os -import fnmatch import re +import fnmatch __all__ = ["glob", "iglob"] @@ -48,13 +49,15 @@ def iglob(pathname): def glob1(dirname, pattern): if not dirname: dirname = os.curdir + if isinstance(pattern, unicode) and not isinstance(dirname, unicode): + dirname = unicode(dirname, sys.getfilesystemencoding()) try: names = os.listdir(dirname) except os.error: return [] - if pattern[0]!='.': - names=filter(lambda x: x[0]!='.',names) - return fnmatch.filter(names,pattern) + if pattern[0] != '.': + names = filter(lambda x: x[0] != '.', names) + return fnmatch.filter(names, pattern) def glob0(dirname, basename): if basename == '': diff --git a/Lib/test/test_glob.py b/Lib/test/test_glob.py index 5ce09f9d10..f1993aba31 100644 --- a/Lib/test/test_glob.py +++ b/Lib/test/test_glob.py @@ -52,6 +52,16 @@ class GlobTests(unittest.TestCase): eq(self.glob('aab'), [self.norm('aab')]) eq(self.glob('zymurgy'), []) + # test return types are unicode, but only if os.listdir + # returns unicode filenames + uniset = set([unicode]) + tmp = os.listdir(u'.') + if set(type(x) for x in tmp) == uniset: + u1 = glob.glob(u'*') + u2 = glob.glob(u'./*') + self.assertEquals(set(type(r) for r in u1), uniset) + self.assertEquals(set(type(r) for r in u2), uniset) + def test_glob_one_directory(self): eq = self.assertSequencesEqual_noorder eq(self.glob('a*'), map(self.norm, ['a', 'aab', 'aaa'])) @@ -152,6 +152,9 @@ Core and builtins Library ------- +- Patch #1001604: glob.glob() now returns unicode filenames if it was + given a unicode argument and os.listdir() returns unicode filenames. + - Patch #1673619: setup.py identifies extension modules it doesn't know how to build and those it knows how to build but that fail to build. |