Commit dc0649f7 authored by Stefan Behnel's avatar Stefan Behnel

Make overflow checking code C89 again.

parent 8c94bfdf
...@@ -158,13 +158,14 @@ static CYTHON_INLINE {{UINT}} __Pyx_mul_const_{{NAME}}_checking_overflow({{UINT} ...@@ -158,13 +158,14 @@ static CYTHON_INLINE {{UINT}} __Pyx_mul_const_{{NAME}}_checking_overflow({{UINT}
// note that deliberately the overflow check is written such that it divides by b; this // note that deliberately the overflow check is written such that it divides by b; this
// function is used when b is a constant thus the compiler should be able to eliminate the // function is used when b is a constant thus the compiler should be able to eliminate the
// (very slow on most CPUs!) division operation // (very slow on most CPUs!) division operation
{{UINT}} prod;
if (__Pyx_is_constant(a) && !__Pyx_is_constant(b)) { if (__Pyx_is_constant(a) && !__Pyx_is_constant(b)) {
// if a is a compile-time constant and b isn't, swap them // if a is a compile-time constant and b isn't, swap them
{{UINT}} temp = b; {{UINT}} temp = b;
b = a; b = a;
a = temp; a = temp;
} }
{{UINT}} prod = a * b; prod = a * b;
if (b != 0) if (b != 0)
*overflow |= a > (__PYX_MAX({{UINT}}) / b); *overflow |= a > (__PYX_MAX({{UINT}}) / b);
return prod; return prod;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment