# HG changeset patch # Parent 2e5fdb8a8874dd85cab9fd6f08639276395cfda3 Issue #24421: Compile _math.c separately to avoid race condition diff -r 2e5fdb8a8874 Makefile.pre.in --- a/Makefile.pre.in Wed Dec 09 02:05:03 2015 +0000 +++ b/Makefile.pre.in Wed Dec 09 04:42:14 2015 +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 2e5fdb8a8874 Misc/NEWS --- a/Misc/NEWS Wed Dec 09 02:05:03 2015 +0000 +++ b/Misc/NEWS Wed Dec 09 04:42:14 2015 +0000 @@ -490,6 +490,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 2e5fdb8a8874 setup.py --- a/setup.py Wed Dec 09 02:05:03 2015 +0000 +++ b/setup.py Wed Dec 09 04:42:14 2015 +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()