diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2017-07-06 05:38:24 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-07-06 05:38:24 (GMT) |
commit | 03b0e8374b2ea93adf8fb6a48db2916f3b0388cc (patch) | |
tree | 12743d6b43e1dff7f8bbacab2b6a5f0bb5a72141 /Lib/importlib | |
parent | aaa4f991518611d101fba1ef3ecb18d7b385ad5b (diff) | |
download | cpython-03b0e8374b2ea93adf8fb6a48db2916f3b0388cc.zip cpython-03b0e8374b2ea93adf8fb6a48db2916f3b0388cc.tar.gz cpython-03b0e8374b2ea93adf8fb6a48db2916f3b0388cc.tar.bz2 |
[3.6] bpo-30814: Fixed a race condition when import a submodule from a package. (GH-2580). (#2598)
(cherry picked from commit b4baacee1adc06edbe30ac7574d17a8cd168e2e0)
Diffstat (limited to 'Lib/importlib')
-rw-r--r-- | Lib/importlib/_bootstrap.py | 28 |
1 files changed, 14 insertions, 14 deletions
diff --git a/Lib/importlib/_bootstrap.py b/Lib/importlib/_bootstrap.py index a531a03..f812a18 100644 --- a/Lib/importlib/_bootstrap.py +++ b/Lib/importlib/_bootstrap.py @@ -956,9 +956,19 @@ def _find_and_load_unlocked(name, import_): def _find_and_load(name, import_): - """Find and load the module, and release the import lock.""" - with _ModuleLockManager(name): - return _find_and_load_unlocked(name, import_) + """Find and load the module.""" + _imp.acquire_lock() + if name not in sys.modules: + with _ModuleLockManager(name): + return _find_and_load_unlocked(name, import_) + module = sys.modules[name] + if module is None: + _imp.release_lock() + message = ('import of {} halted; ' + 'None in sys.modules'.format(name)) + raise ModuleNotFoundError(message, name=name) + _lock_unlock_module(name) + return module def _gcd_import(name, package=None, level=0): @@ -973,17 +983,7 @@ def _gcd_import(name, package=None, level=0): _sanity_check(name, package, level) if level > 0: name = _resolve_name(name, package, level) - _imp.acquire_lock() - if name not in sys.modules: - return _find_and_load(name, _gcd_import) - module = sys.modules[name] - if module is None: - _imp.release_lock() - message = ('import of {} halted; ' - 'None in sys.modules'.format(name)) - raise ModuleNotFoundError(message, name=name) - _lock_unlock_module(name) - return module + return _find_and_load(name, _gcd_import) def _handle_fromlist(module, fromlist, import_): |