]> granicus.if.org Git - python/commitdiff
run_module shouldn't hold the import lock when running a script
authorNick Coghlan <ncoghlan@gmail.com>
Fri, 24 Mar 2006 13:05:53 +0000 (13:05 +0000)
committerNick Coghlan <ncoghlan@gmail.com>
Fri, 24 Mar 2006 13:05:53 +0000 (13:05 +0000)
Lib/runpy.py

index afb00982923dc989f35aa1afe00f9294fd1c7952..496b095a3197856343be4436fd97fee96b00d484 100755 (executable)
@@ -379,21 +379,17 @@ def _run_module_code(code, init_globals=None,
         restore_module = mod_name in sys.modules
         if restore_module:
             saved_module = sys.modules[mod_name]
-        imp.acquire_lock()
+        sys.argv[0] = mod_fname
+        sys.modules[mod_name] = temp_module
         try:
-            sys.argv[0] = mod_fname
-            sys.modules[mod_name] = temp_module
-            try:
-                _run_code(code, mod_globals, init_globals,
-                          mod_name, mod_fname, mod_loader)
-            finally:
-                sys.argv[0] = saved_argv0
-                if restore_module:
-                    sys.modules[mod_name] = saved_module
-                else:
-                    del sys.modules[mod_name]
+            _run_code(code, mod_globals, init_globals,
+                      mod_name, mod_fname, mod_loader)
         finally:
-            imp.release_lock()
+            sys.argv[0] = saved_argv0
+        if restore_module:
+                sys.modules[mod_name] = saved_module
+        else:
+                del sys.modules[mod_name]
         # Copy the globals of the temporary module, as they
         # may be cleared when the temporary module goes away
         return mod_globals.copy()