summaryrefslogtreecommitdiffstats
path: root/Lib/importlib
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2017-07-06 05:38:24 (GMT)
committerGitHub <noreply@github.com>2017-07-06 05:38:24 (GMT)
commit03b0e8374b2ea93adf8fb6a48db2916f3b0388cc (patch)
tree12743d6b43e1dff7f8bbacab2b6a5f0bb5a72141 /Lib/importlib
parentaaa4f991518611d101fba1ef3ecb18d7b385ad5b (diff)
downloadcpython-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.py28
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_):