summaryrefslogtreecommitdiffstats
path: root/Objects/complexobject.c
diff options
context:
space:
mode:
authorAntoine Pitrou <solipsis@pitrou.net>2014-10-10 21:51:04 (GMT)
committerAntoine Pitrou <solipsis@pitrou.net>2014-10-10 21:51:04 (GMT)
commit759920c5cb7aa8f9218b35148a3e4fb129cb86f2 (patch)
treee59e52ff9ea28029407eaf58c8e3813f8fd9cf62 /Objects/complexobject.c
parentfc260a9a97156cc1cfee88b5947ed99d6b37025a (diff)
parent9086f9260f1f48a231cba4e7123eb7ac8159ba40 (diff)
downloadcpython-759920c5cb7aa8f9218b35148a3e4fb129cb86f2.zip
cpython-759920c5cb7aa8f9218b35148a3e4fb129cb86f2.tar.gz
cpython-759920c5cb7aa8f9218b35148a3e4fb129cb86f2.tar.bz2
Issue #22604: Fix assertion error in debug mode when dividing a complex number by (nan+0j).
Diffstat (limited to 'Objects/complexobject.c')
-rw-r--r--Objects/complexobject.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/Objects/complexobject.c b/Objects/complexobject.c
index b66aed1..7e2e88a 100644
--- a/Objects/complexobject.c
+++ b/Objects/complexobject.c
@@ -78,7 +78,7 @@ _Py_c_quot(Py_complex a, Py_complex b)
const double abs_breal = b.real < 0 ? -b.real : b.real;
const double abs_bimag = b.imag < 0 ? -b.imag : b.imag;
- if (abs_breal >= abs_bimag) {
+ if (abs_breal >= abs_bimag) {
/* divide tops and bottom by b.real */
if (abs_breal == 0.0) {
errno = EDOM;
@@ -91,7 +91,7 @@ _Py_c_quot(Py_complex a, Py_complex b)
r.imag = (a.imag - a.real * ratio) / denom;
}
}
- else {
+ else if (abs_bimag >= abs_breal) {
/* divide tops and bottom by b.imag */
const double ratio = b.real / b.imag;
const double denom = b.real * ratio + b.imag;
@@ -99,6 +99,10 @@ _Py_c_quot(Py_complex a, Py_complex b)
r.real = (a.real * ratio + a.imag) / denom;
r.imag = (a.imag * ratio - a.real) / denom;
}
+ else {
+ /* At least one of b.real or b.imag is a NaN */
+ r.real = r.imag = Py_NAN;
+ }
return r;
}