diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2012-02-20 21:06:59 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2012-02-20 21:06:59 (GMT) |
commit | b5c793a0b349cb02003433c30a410595b224079f (patch) | |
tree | 60c03d98630de88e9ad9ff47fc488c3a8ecff221 | |
parent | 6ddac006be85b839c9590aa2ec802b61f785f7e2 (diff) | |
download | cpython-b5c793a0b349cb02003433c30a410595b224079f.zip cpython-b5c793a0b349cb02003433c30a410595b224079f.tar.gz cpython-b5c793a0b349cb02003433c30a410595b224079f.tar.bz2 |
Issue #14063: fix test_importlib failure under OS X case-insensitive filesystems
(regression)
-rw-r--r-- | Lib/importlib/_bootstrap.py | 26 |
1 files changed, 15 insertions, 11 deletions
diff --git a/Lib/importlib/_bootstrap.py b/Lib/importlib/_bootstrap.py index 7ebb723..f70869e 100644 --- a/Lib/importlib/_bootstrap.py +++ b/Lib/importlib/_bootstrap.py @@ -762,13 +762,12 @@ class _FileFinder: self.path = path or '.' self._path_mtime = -1 self._path_cache = set() + self._relaxed_path_cache = set() self._cache_refresh = 0 def find_module(self, fullname): """Try to find a loader for the specified module.""" tail_module = fullname.rpartition('.')[2] - if _relax_case(): - tail_module = tail_module.lower() try: mtime = _os.stat(self.path).st_mtime except OSError: @@ -777,8 +776,14 @@ class _FileFinder: self._fill_cache() self._path_mtime = mtime self._cache_refresh = _cache_refresh - cache = self._path_cache - if tail_module in cache: + # tail_module keeps the original casing, for __file__ and friends + if _relax_case(): + cache = self._relaxed_path_cache + cache_module = tail_module.lower() + else: + cache = self._path_cache + cache_module = tail_module + if cache_module in cache: base_path = _path_join(self.path, tail_module) if _path_isdir(base_path): for suffix, loader in self.packages: @@ -790,9 +795,8 @@ class _FileFinder: msg = "Not importing directory {}: missing __init__" _warnings.warn(msg.format(base_path), ImportWarning) for suffix, loader in self.modules: - mod_filename = tail_module + suffix - if mod_filename in cache: - full_path = _path_join(self.path, mod_filename) + if cache_module + suffix in cache: + full_path = _path_join(self.path, tail_module + suffix) if _path_isfile(full_path): return loader(fullname, full_path) return None @@ -801,10 +805,10 @@ class _FileFinder: """Fill the cache of potential modules and packages for this directory.""" path = self.path contents = _os.listdir(path) - if _relax_case(): - self._path_cache = set(fn.lower() for fn in contents) - else: - self._path_cache = set(contents) + # We store two cached versions, to handle runtime changes of the + # PYTHONCASEOK environment variable. + self._path_cache = set(contents) + self._relaxed_path_cache = set(fn.lower() for fn in contents) class _SourceFinderDetails: |