Index: bootstrap/virtualenv/virtualenv_embedded/distutils-init.py |
diff --git a/bootstrap/virtualenv/virtualenv_embedded/distutils-init.py b/bootstrap/virtualenv/virtualenv_embedded/distutils-init.py |
new file mode 100644 |
index 0000000000000000000000000000000000000000..29fc1da45900ece22ff3ebb73a6b7ccf607e6a1a |
--- /dev/null |
+++ b/bootstrap/virtualenv/virtualenv_embedded/distutils-init.py |
@@ -0,0 +1,101 @@ |
+import os |
+import sys |
+import warnings |
+import imp |
+import opcode # opcode is not a virtualenv module, so we can use it to find the stdlib |
+ # Important! To work on pypy, this must be a module that resides in the |
+ # lib-python/modified-x.y.z directory |
+ |
+dirname = os.path.dirname |
+ |
+distutils_path = os.path.join(os.path.dirname(opcode.__file__), 'distutils') |
+if os.path.normpath(distutils_path) == os.path.dirname(os.path.normpath(__file__)): |
+ warnings.warn( |
+ "The virtualenv distutils package at %s appears to be in the same location as the system distutils?") |
+else: |
+ __path__.insert(0, distutils_path) |
+ real_distutils = imp.load_module("_virtualenv_distutils", None, distutils_path, ('', '', imp.PKG_DIRECTORY)) |
+ # Copy the relevant attributes |
+ try: |
+ __revision__ = real_distutils.__revision__ |
+ except AttributeError: |
+ pass |
+ __version__ = real_distutils.__version__ |
+ |
+from distutils import dist, sysconfig |
+ |
+try: |
+ basestring |
+except NameError: |
+ basestring = str |
+ |
+## patch build_ext (distutils doesn't know how to get the libs directory |
+## path on windows - it hardcodes the paths around the patched sys.prefix) |
+ |
+if sys.platform == 'win32': |
+ from distutils.command.build_ext import build_ext as old_build_ext |
+ class build_ext(old_build_ext): |
+ def finalize_options (self): |
+ if self.library_dirs is None: |
+ self.library_dirs = [] |
+ elif isinstance(self.library_dirs, basestring): |
+ self.library_dirs = self.library_dirs.split(os.pathsep) |
+ |
+ self.library_dirs.insert(0, os.path.join(sys.real_prefix, "Libs")) |
+ old_build_ext.finalize_options(self) |
+ |
+ from distutils.command import build_ext as build_ext_module |
+ build_ext_module.build_ext = build_ext |
+ |
+## distutils.dist patches: |
+ |
+old_find_config_files = dist.Distribution.find_config_files |
+def find_config_files(self): |
+ found = old_find_config_files(self) |
+ system_distutils = os.path.join(distutils_path, 'distutils.cfg') |
+ #if os.path.exists(system_distutils): |
+ # found.insert(0, system_distutils) |
+ # What to call the per-user config file |
+ if os.name == 'posix': |
+ user_filename = ".pydistutils.cfg" |
+ else: |
+ user_filename = "pydistutils.cfg" |
+ user_filename = os.path.join(sys.prefix, user_filename) |
+ if os.path.isfile(user_filename): |
+ for item in list(found): |
+ if item.endswith('pydistutils.cfg'): |
+ found.remove(item) |
+ found.append(user_filename) |
+ return found |
+dist.Distribution.find_config_files = find_config_files |
+ |
+## distutils.sysconfig patches: |
+ |
+old_get_python_inc = sysconfig.get_python_inc |
+def sysconfig_get_python_inc(plat_specific=0, prefix=None): |
+ if prefix is None: |
+ prefix = sys.real_prefix |
+ return old_get_python_inc(plat_specific, prefix) |
+sysconfig_get_python_inc.__doc__ = old_get_python_inc.__doc__ |
+sysconfig.get_python_inc = sysconfig_get_python_inc |
+ |
+old_get_python_lib = sysconfig.get_python_lib |
+def sysconfig_get_python_lib(plat_specific=0, standard_lib=0, prefix=None): |
+ if standard_lib and prefix is None: |
+ prefix = sys.real_prefix |
+ return old_get_python_lib(plat_specific, standard_lib, prefix) |
+sysconfig_get_python_lib.__doc__ = old_get_python_lib.__doc__ |
+sysconfig.get_python_lib = sysconfig_get_python_lib |
+ |
+old_get_config_vars = sysconfig.get_config_vars |
+def sysconfig_get_config_vars(*args): |
+ real_vars = old_get_config_vars(*args) |
+ if sys.platform == 'win32': |
+ lib_dir = os.path.join(sys.real_prefix, "libs") |
+ if isinstance(real_vars, dict) and 'LIBDIR' not in real_vars: |
+ real_vars['LIBDIR'] = lib_dir # asked for all |
+ elif isinstance(real_vars, list) and 'LIBDIR' in args: |
+ real_vars = real_vars + [lib_dir] # asked for list |
+ return real_vars |
+sysconfig_get_config_vars.__doc__ = old_get_config_vars.__doc__ |
+sysconfig.get_config_vars = sysconfig_get_config_vars |