]> granicus.if.org Git - python/commitdiff
Issue #13889: Add missing _Py_SET_53BIT_PRECISION_* calls around uses of dtoa.c funct...
authorMark Dickinson <mdickinson@enthought.com>
Fri, 27 Jan 2012 21:16:01 +0000 (21:16 +0000)
committerMark Dickinson <mdickinson@enthought.com>
Fri, 27 Jan 2012 21:16:01 +0000 (21:16 +0000)
Objects/floatobject.c

index 09c0e961ba54bdc863f3adfaba0896c8e4121ef8..e146a4fc7c7ead7b5b041d60433c90582536c529 100644 (file)
@@ -919,9 +919,12 @@ double_round(double x, int ndigits) {
     char *buf, *buf_end, shortbuf[100], *mybuf=shortbuf;
     int decpt, sign;
     PyObject *result = NULL;
+    _Py_SET_53BIT_PRECISION_HEADER;
 
     /* round to a decimal string */
+    _Py_SET_53BIT_PRECISION_START;
     buf = _Py_dg_dtoa(x, 3, ndigits, &decpt, &sign, &buf_end);
+    _Py_SET_53BIT_PRECISION_END;
     if (buf == NULL) {
         PyErr_NoMemory();
         return NULL;
@@ -944,7 +947,9 @@ double_round(double x, int ndigits) {
 
     /* and convert the resulting string back to a double */
     errno = 0;
+    _Py_SET_53BIT_PRECISION_START;
     rounded = _Py_dg_strtod(mybuf, NULL);
+    _Py_SET_53BIT_PRECISION_END;
     if (errno == ERANGE && fabs(rounded) >= 1.)
         PyErr_SetString(PyExc_OverflowError,
                         "rounded value too large to represent");