summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVictor Stinner <vstinner@python.org>2021-10-11 22:12:00 (GMT)
committerGitHub <noreply@github.com>2021-10-11 22:12:00 (GMT)
commit61190e092b8258ede92ac543bb39bad0f7168104 (patch)
treeebebc990118186a36116fe6026fe5a03d3594e8c
parent1f316ea3b4fa319eec4f375fb683467b424c964e (diff)
downloadcpython-61190e092b8258ede92ac543bb39bad0f7168104.zip
cpython-61190e092b8258ede92ac543bb39bad0f7168104.tar.gz
cpython-61190e092b8258ede92ac543bb39bad0f7168104.tar.bz2
bpo-45412: Move copysign() define to pycore_pymath.h (GH-28889)
Move definitions of copysign(), round(), hypot(), fmod(), etc. from pymath.h to pycore_pymath.h. These functions are not exported by libpython and so must not be part of the C API.
-rw-r--r--Include/internal/pycore_pymath.h28
-rw-r--r--Include/pymath.h73
2 files changed, 49 insertions, 52 deletions
diff --git a/Include/internal/pycore_pymath.h b/Include/internal/pycore_pymath.h
index b1a2004..38f76d0 100644
--- a/Include/internal/pycore_pymath.h
+++ b/Include/internal/pycore_pymath.h
@@ -8,6 +8,34 @@ extern "C" {
# error "this header requires Py_BUILD_CORE define"
#endif
+
+// Python provides implementations for copysign(), round() and hypot() in
+// Python/pymath.c just in case your math library doesn't provide the
+// functions.
+//
+// Note: PC/pyconfig.h defines copysign as _copysign
+#ifndef HAVE_COPYSIGN
+extern double copysign(double, double);
+#endif
+
+#ifndef HAVE_ROUND
+extern double round(double);
+#endif
+
+#ifndef HAVE_HYPOT
+extern double hypot(double, double);
+#endif
+
+// Extra declarations
+#if !defined(_MSC_VER) && !defined(__STDC__)
+extern double fmod (double, double);
+extern double frexp (double, int *);
+extern double ldexp (double, int);
+extern double modf (double, double *);
+extern double pow(double, double);
+#endif // !defined(_MSC_VER) && !defined(__STDC__)
+
+
/* _Py_ADJUST_ERANGE1(x)
* _Py_ADJUST_ERANGE2(x, y)
* Set errno to 0 before calling a libm function, and invoke one of these
diff --git a/Include/pymath.h b/Include/pymath.h
index 2f47f87..d688e50 100644
--- a/Include/pymath.h
+++ b/Include/pymath.h
@@ -1,41 +1,10 @@
+// Symbols and macros to supply platform-independent interfaces to mathematical
+// functions and constants.
+
#ifndef Py_PYMATH_H
#define Py_PYMATH_H
-#include "pyconfig.h" /* include for defines */
-
-/**************************************************************************
-Symbols and macros to supply platform-independent interfaces to mathematical
-functions and constants
-**************************************************************************/
-
-/* Python provides implementations for copysign, round and hypot in
- * Python/pymath.c just in case your math library doesn't provide the
- * functions.
- *
- *Note: PC/pyconfig.h defines copysign as _copysign
- */
-#ifndef HAVE_COPYSIGN
-extern double copysign(double, double);
-#endif
-
-#ifndef HAVE_ROUND
-extern double round(double);
-#endif
-
-#ifndef HAVE_HYPOT
-extern double hypot(double, double);
-#endif
-
-/* extra declarations */
-#ifndef _MSC_VER
-#ifndef __STDC__
-extern double fmod (double, double);
-extern double frexp (double, int *);
-extern double ldexp (double, int);
-extern double modf (double, double *);
-extern double pow(double, double);
-#endif /* __STDC__ */
-#endif /* _MSC_VER */
+#include "pyconfig.h" // HAVE_DECL_ISNAN
/* High precision definition of pi and e (Euler)
* The values are taken from libc6's math.h.
@@ -123,13 +92,13 @@ PyAPI_FUNC(double) _Py_force_double(double);
* Note: PC/pyconfig.h defines Py_IS_FINITE as _finite
*/
#ifndef Py_IS_FINITE
-#if defined HAVE_DECL_ISFINITE && HAVE_DECL_ISFINITE == 1
-#define Py_IS_FINITE(X) isfinite(X)
-#elif defined HAVE_FINITE
-#define Py_IS_FINITE(X) finite(X)
-#else
-#define Py_IS_FINITE(X) (!Py_IS_INFINITY(X) && !Py_IS_NAN(X))
-#endif
+# if defined HAVE_DECL_ISFINITE && HAVE_DECL_ISFINITE == 1
+# define Py_IS_FINITE(X) isfinite(X)
+# elif defined HAVE_FINITE
+# define Py_IS_FINITE(X) finite(X)
+# else
+# define Py_IS_FINITE(X) (!Py_IS_INFINITY(X) && !Py_IS_NAN(X))
+# endif
#endif
/* HUGE_VAL is supposed to expand to a positive double infinity. Python
@@ -140,7 +109,7 @@ PyAPI_FUNC(double) _Py_force_double(double);
* config to #define Py_HUGE_VAL to something that works on your platform.
*/
#ifndef Py_HUGE_VAL
-#define Py_HUGE_VAL HUGE_VAL
+# define Py_HUGE_VAL HUGE_VAL
#endif
/* Py_NAN
@@ -149,10 +118,10 @@ PyAPI_FUNC(double) _Py_force_double(double);
* doesn't support NaNs.
*/
#if !defined(Py_NAN) && !defined(Py_NO_NAN)
-#if !defined(__INTEL_COMPILER)
- #define Py_NAN (Py_HUGE_VAL * 0.)
-#else /* __INTEL_COMPILER */
- #if defined(ICC_NAN_STRICT)
+# if !defined(__INTEL_COMPILER)
+# define Py_NAN (Py_HUGE_VAL * 0.)
+# else /* __INTEL_COMPILER */
+# if defined(ICC_NAN_STRICT)
#pragma float_control(push)
#pragma float_control(precise, on)
#pragma float_control(except, on)
@@ -161,12 +130,12 @@ PyAPI_FUNC(double) _Py_force_double(double);
return sqrt(-1.0);
}
#pragma float_control (pop)
- #define Py_NAN __icc_nan()
- #else /* ICC_NAN_RELAXED as default for Intel Compiler */
+# define Py_NAN __icc_nan()
+# else /* ICC_NAN_RELAXED as default for Intel Compiler */
static const union { unsigned char buf[8]; double __icc_nan; } __nan_store = {0,0,0,0,0,0,0xf8,0x7f};
- #define Py_NAN (__nan_store.__icc_nan)
- #endif /* ICC_NAN_STRICT */
-#endif /* __INTEL_COMPILER */
+# define Py_NAN (__nan_store.__icc_nan)
+# endif /* ICC_NAN_STRICT */
+# endif /* __INTEL_COMPILER */
#endif
#endif /* Py_PYMATH_H */