diff options
author | Hanno Schlichting <hanno@hannosch.eu> | 2009-07-17 14:49:13 +0200 |
---|---|---|
committer | Hanno Schlichting <hanno@hannosch.eu> | 2009-07-17 14:49:13 +0200 |
commit | d7db8bf8f402130e3ce49603ead50de5f7a4d6b2 (patch) | |
tree | 5e15dd392d07e7d31846cb4bce1c6f82e8837b48 /setuptools | |
parent | 8f8af6ab1d828d557dad61375eb520f3f12ad496 (diff) | |
download | external_python_setuptools-d7db8bf8f402130e3ce49603ead50de5f7a4d6b2.tar.gz external_python_setuptools-d7db8bf8f402130e3ce49603ead50de5f7a4d6b2.tar.bz2 external_python_setuptools-d7db8bf8f402130e3ce49603ead50de5f7a4d6b2.zip |
Packages required at build time where not fully present at install time. This closes #12.
--HG--
branch : distribute
extra : rebase_source : 178f508c83ecab9244064108d55ce840111a0e34
Diffstat (limited to 'setuptools')
-rwxr-xr-x | setuptools/sandbox.py | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/setuptools/sandbox.py b/setuptools/sandbox.py index 97865dd9..11c14938 100755 --- a/setuptools/sandbox.py +++ b/setuptools/sandbox.py @@ -6,10 +6,8 @@ from distutils.errors import DistutilsError __all__ = [ "AbstractSandbox", "DirectorySandbox", "SandboxViolation", "run_setup", ] - def run_setup(setup_script, args): """Run a distutils setup script, sandboxed in its directory""" - old_dir = os.getcwd() save_argv = sys.argv[:] save_path = sys.path[:] @@ -17,7 +15,7 @@ def run_setup(setup_script, args): temp_dir = os.path.join(setup_dir,'temp') if not os.path.isdir(temp_dir): os.makedirs(temp_dir) save_tmp = tempfile.tempdir - + save_modules = sys.modules.copy() try: tempfile.tempdir = temp_dir os.chdir(setup_dir) @@ -35,6 +33,9 @@ def run_setup(setup_script, args): raise # Normal exit, just return finally: + sys.modules.update(save_modules) + for key in list(sys.modules): + if key not in save_modules: del sys.modules[key] os.chdir(old_dir) sys.path[:] = save_path sys.argv[:] = save_argv |