diff options
author | Nick Coghlan <ncoghlan@gmail.com> | 2007-08-25 04:32:07 (GMT) |
---|---|---|
committer | Nick Coghlan <ncoghlan@gmail.com> | 2007-08-25 04:32:07 (GMT) |
commit | 3af0e785e70164dc6c779d49f6815058e26050be (patch) | |
tree | da45f17cd8969684877795e9861c1d72608dde44 /Lib/runpy.py | |
parent | 68f525fdc8e48425637c4aa712c0ea42e1e26798 (diff) | |
download | cpython-3af0e785e70164dc6c779d49f6815058e26050be.zip cpython-3af0e785e70164dc6c779d49f6815058e26050be.tar.gz cpython-3af0e785e70164dc6c779d49f6815058e26050be.tar.bz2 |
Revert misguided attempt at fixing incompatibility between -m and -i switches (better fix coming soon)
Diffstat (limited to 'Lib/runpy.py')
-rwxr-xr-x | Lib/runpy.py | 33 |
1 files changed, 24 insertions, 9 deletions
diff --git a/Lib/runpy.py b/Lib/runpy.py index 8096aac..d2f18d3 100755 --- a/Lib/runpy.py +++ b/Lib/runpy.py @@ -33,21 +33,36 @@ def _run_code(code, run_globals, init_globals, return run_globals def _run_module_code(code, init_globals=None, - mod_name=None, mod_fname=None, - mod_loader=None, alter_sys=False): + mod_name=None, mod_fname=None, + mod_loader=None, alter_sys=False): """Helper for run_module""" # Set up the top level namespace dictionary if alter_sys: - # Modify sys.argv[0] and sys.modules[mod_name] + # Modify sys.argv[0] and sys.module[mod_name] + temp_module = imp.new_module(mod_name) + mod_globals = temp_module.__dict__ + saved_argv0 = sys.argv[0] + restore_module = mod_name in sys.modules + if restore_module: + saved_module = sys.modules[mod_name] sys.argv[0] = mod_fname - module = imp.new_module(mod_name) - sys.modules[mod_name] = module - mod_globals = module.__dict__ + 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] + # Copy the globals of the temporary module, as they + # may be cleared when the temporary module goes away + return mod_globals.copy() else: # Leave the sys module alone - mod_globals = {} - return _run_code(code, mod_globals, init_globals, - mod_name, mod_fname, mod_loader) + return _run_code(code, {}, init_globals, + mod_name, mod_fname, mod_loader) # This helper is needed due to a missing component in the PEP 302 |