summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBarry Warsaw <barry@python.org>2010-11-24 20:30:00 (GMT)
committerBarry Warsaw <barry@python.org>2010-11-24 20:30:00 (GMT)
commit807bd0a8a47191f7aa25cd9d5619bbc46a3f2a2a (patch)
tree148ed83bbd11d82bc3b895c857e3f643775b6f3c
parent1b9df3962088142300728724c485425a93eb5f2a (diff)
downloadcpython-807bd0a8a47191f7aa25cd9d5619bbc46a3f2a2a.zip
cpython-807bd0a8a47191f7aa25cd9d5619bbc46a3f2a2a.tar.gz
cpython-807bd0a8a47191f7aa25cd9d5619bbc46a3f2a2a.tar.bz2
Put /usr/local paths after the relative paths in library_dirs and
include_dirs, so installed non-matching shared libraries don't break extension module linking. Fixes issue 10520.
-rw-r--r--setup.py26
1 files changed, 18 insertions, 8 deletions
diff --git a/setup.py b/setup.py
index d7d482e..a6d0af1 100644
--- a/setup.py
+++ b/setup.py
@@ -27,11 +27,18 @@ disabled_module_list = []
_BUILDDIR_COOKIE = "pybuilddir.txt"
def add_dir_to_list(dirlist, dir):
- """Add the directory 'dir' to the list 'dirlist' (at the front) if
+ """Add the directory 'dir' to the list 'dirlist' (after any relative
+ directories) if:
+
1) 'dir' is not already in 'dirlist'
- 2) 'dir' actually exists, and is a directory."""
- if dir is not None and os.path.isdir(dir) and dir not in dirlist:
- dirlist.insert(0, dir)
+ 2) 'dir' actually exists, and is a directory.
+ """
+ if dir is None or not os.path.isdir(dir) or dir in dirlist:
+ return
+ for i, path in enumerate(dirlist):
+ if not os.path.isabs(path):
+ dirlist.insert(i + 1, dir)
+ break
def macosx_sdk_root():
"""
@@ -362,7 +369,9 @@ class PyBuildExt(build_ext):
return sys.platform
def detect_modules(self):
- # Ensure that /usr/local is always used
+ # Ensure that /usr/local is always used, but the local build
+ # directories (i.e. '.' and 'Include') must be first. See issue
+ # 10520.
add_dir_to_list(self.compiler.library_dirs, '/usr/local/lib')
add_dir_to_list(self.compiler.include_dirs, '/usr/local/include')
@@ -437,9 +446,10 @@ class PyBuildExt(build_ext):
# This should work on any unixy platform ;-)
# If the user has bothered specifying additional -I and -L flags
# in OPT and LDFLAGS we might as well use them here.
- # NOTE: using shlex.split would technically be more correct, but
- # also gives a bootstrap problem. Let's hope nobody uses directories
- # with whitespace in the name to store libraries.
+ #
+ # NOTE: using shlex.split would technically be more correct, but
+ # also gives a bootstrap problem. Let's hope nobody uses
+ # directories with whitespace in the name to store libraries.
cflags, ldflags = sysconfig.get_config_vars(
'CFLAGS', 'LDFLAGS')
for item in cflags.split():