changeset: 100143:76624d47ee99 user: Martin Panter date: Wed Feb 03 05:19:44 2016 +0000 files: Makefile.pre.in Misc/NEWS setup.py description: Issue #24421: Compile _math.c separately to avoid race condition diff -r 0731f097157b -r 76624d47ee99 Makefile.pre.in --- a/Makefile.pre.in Mon Feb 01 21:21:19 2016 -0800 +++ b/Makefile.pre.in Wed Feb 03 05:19:44 2016 +0000 @@ -586,11 +586,15 @@ exit 1 ; \ fi +# This is shared by the math and cmath modules +Modules/_math.o: Modules/_math.c Modules/_math.h + $(CC) -c $(CCSHARED) $(PY_CORE_CFLAGS) -o $@ $< + # Build the shared modules # Under GNU make, MAKEFLAGS are sorted and normalized; the 's' for # -s, --silent or --quiet is always the first char. # Under BSD make, MAKEFLAGS might be " -s -v x=y". -sharedmods: $(BUILDPYTHON) pybuilddir.txt +sharedmods: $(BUILDPYTHON) pybuilddir.txt Modules/_math.o @case "$$MAKEFLAGS" in \ *\ -s*|s*) quiet="-q";; \ *) quiet="";; \ diff -r 0731f097157b -r 76624d47ee99 Misc/NEWS --- a/Misc/NEWS Mon Feb 01 21:21:19 2016 -0800 +++ b/Misc/NEWS Wed Feb 03 05:19:44 2016 +0000 @@ -671,6 +671,10 @@ - Issue #24986: It is now possible to build Python on Windows without errors when external libraries are not available. +- Issue #24421: Compile Modules/_math.c once, before building extensions. + Previously it could fail to compile properly if the math and cmath builds + were concurrent. + - Issue #25798: Update OS X 10.5 installer to use OpenSSL 1.0.2e. Windows diff -r 0731f097157b -r 76624d47ee99 setup.py --- a/setup.py Mon Feb 01 21:21:19 2016 -0800 +++ b/setup.py Wed Feb 03 05:19:44 2016 +0000 @@ -582,13 +582,17 @@ # array objects exts.append( Extension('array', ['arraymodule.c']) ) + + shared_math = 'Modules/_math.o' # complex math library functions - exts.append( Extension('cmath', ['cmathmodule.c', '_math.c'], - depends=['_math.h'], + exts.append( Extension('cmath', ['cmathmodule.c'], + extra_objects=[shared_math], + depends=['_math.h', shared_math], libraries=math_libs) ) # math library functions, e.g. sin() - exts.append( Extension('math', ['mathmodule.c', '_math.c'], - depends=['_math.h'], + exts.append( Extension('math', ['mathmodule.c'], + extra_objects=[shared_math], + depends=['_math.h', shared_math], libraries=math_libs) ) # time libraries: librt may be needed for clock_gettime()