]> granicus.if.org Git - python/commitdiff
Change PyFPE_END_PROTECT to PyFPE_END_PROTECT(v). v should be the
authorGuido van Rossum <guido@python.org>
Fri, 14 Mar 1997 04:23:42 +0000 (04:23 +0000)
committerGuido van Rossum <guido@python.org>
Fri, 14 Mar 1997 04:23:42 +0000 (04:23 +0000)
last variable to which a floating point expression is assigned.  The
macro passes its address to a dummy function so that the optimizer
can't delay calculating its value until after the macro.

Include/pyfpe.h

index ef44e6620827812c1e1908d88672dea13c8105bf..b2d8feed9394897a458a5dadd811d54a5cb25748 100644 (file)
@@ -131,7 +131,7 @@ extern "C" {
 #include <math.h>
 extern jmp_buf PyFPE_jbuf;
 extern int PyFPE_counter;
-extern double PyFPE_dummy(void);
+extern double PyFPE_dummy();
 
 #define PyFPE_START_PROTECT(err_string, leave_stmt) \
 if (!PyFPE_counter++ && setjmp(PyFPE_jbuf)) { \
@@ -149,12 +149,12 @@ if (!PyFPE_counter++ && setjmp(PyFPE_jbuf)) { \
  * which counts down PyFPE_counter, and thereby monkey wrench the overeager
  * optimizer. Better solutions are welcomed....
  */
-#define PyFPE_END_PROTECT PyFPE_counter -= (int)PyFPE_dummy();
+#define PyFPE_END_PROTECT(v) PyFPE_counter -= (int)PyFPE_dummy(&(v));
 
 #else
 
 #define PyFPE_START_PROTECT(err_string, leave_stmt)
-#define PyFPE_END_PROTECT
+#define PyFPE_END_PROTECT(v)
 
 #endif