]> granicus.if.org Git - python/commitdiff
Without this patch the value of sysconfig.get_config_var('LDSHARED')
authorRonald Oussoren <ronaldoussoren@mac.com>
Tue, 20 Jul 2010 16:07:10 +0000 (16:07 +0000)
committerRonald Oussoren <ronaldoussoren@mac.com>
Tue, 20 Jul 2010 16:07:10 +0000 (16:07 +0000)
is wrong when PY_LDFLAGS is not empty.

The bug was caused by LDSHARED getting expanded *before* sysconfig
renamed PY_LDSHARED (and simular values) to names without a PY_
prefix.

The patch tries to maintain the intended behaviour of allowing users
to set LDFLAGS in the environment and have that affect the build.

Without this patch a universal build on OSX cannot build universal
(fat binary) extensions.

Lib/sysconfig.py

index 28731dfdc1660243157aa0a20d4448e602d4d969..2fec9102bc6fdd2df87a3d06d1ea0afef0f23f36 100644 (file)
@@ -225,6 +225,12 @@ def _parse_makefile(filename, vars=None):
     # do variable interpolation here
     variables = list(notdone.keys())
 
+    # Variables with a 'PY_' prefix in the makefile. These need to
+    # be made available without that prefix through sysconfig.
+    # Special care is needed to ensure that variable expansion works, even
+    # if the expansion uses the name without a prefix.
+    renamed_variables = ('CFLAGS', 'LDFLAGS', 'CPPFLAGS')
+
     while len(variables) > 0:
         for name in tuple(variables):
             value = notdone[name]
@@ -240,8 +246,20 @@ def _parse_makefile(filename, vars=None):
                 elif n in os.environ:
                     # do it like make: fall back to environment
                     item = os.environ[n]
+
+                elif n in renamed_variables:
+                    if name.startswith('PY_') and name[3:] in renamed_variables:
+                        item = ""
+
+                    elif 'PY_' + n in notdone:
+                        found = False
+
+                    else:
+                        item = str(done['PY_' + n])
+
                 else:
                     done[n] = item = ""
+
                 if found:
                     after = value[m.end():]
                     value = value[:m.start()] + item + after
@@ -255,17 +273,19 @@ def _parse_makefile(filename, vars=None):
                         else:
                             done[name] = value
                         variables.remove(name)
+
+                        if name.startswith('PY_') \
+                                and name[3:] in renamed_variables:
+
+                            name = name[3:]
+                            if name not in done:
+                                done[name] = value
+
+
             else:
                 # bogus variable reference; just drop it since we can't deal
                 variables.remove(name)
 
-    # Add in CFLAGS, LDFLAGS, and CPPFLAGS, which are named with a
-    # prefix in the Makefile.
-    for var in ('CFLAGS', 'LDFLAGS', 'CPPFLAGS'):
-        makefile_value = done.get('PY_' + var)
-        if makefile_value is not None:
-            done[var] = makefile_value
-
     # save the results in the global dictionary
     vars.update(done)
     return vars