diff options
author | Meador Inge <meadori@gmail.com> | 2012-05-28 19:21:16 (GMT) |
---|---|---|
committer | Meador Inge <meadori@gmail.com> | 2012-05-28 19:21:16 (GMT) |
commit | 031e25b0f74ae2c7c82a6d2a3c227e74278b22d9 (patch) | |
tree | 529eef2863c5a611a2e0cab151a92f4697ac9e0e /Modules | |
parent | 4b6045c30fb47a89cd32ebedc2b8d2603cd72e33 (diff) | |
download | cpython-031e25b0f74ae2c7c82a6d2a3c227e74278b22d9.zip cpython-031e25b0f74ae2c7c82a6d2a3c227e74278b22d9.tar.gz cpython-031e25b0f74ae2c7c82a6d2a3c227e74278b22d9.tar.bz2 |
Issue #9041: raised exception is misleading
An issue in ctypes.c_longdouble, ctypes.c_double, and ctypes.c_float that
caused an incorrect exception to be returned in the case of overflow has been
fixed.
Diffstat (limited to 'Modules')
-rw-r--r-- | Modules/_ctypes/cfield.c | 30 |
1 files changed, 5 insertions, 25 deletions
diff --git a/Modules/_ctypes/cfield.c b/Modules/_ctypes/cfield.c index e2d1e4b..4005465 100644 --- a/Modules/_ctypes/cfield.c +++ b/Modules/_ctypes/cfield.c @@ -1002,12 +1002,8 @@ g_set(void *ptr, PyObject *value, Py_ssize_t size) long double x; x = PyFloat_AsDouble(value); - if (x == -1 && PyErr_Occurred()) { - PyErr_Format(PyExc_TypeError, - " float expected instead of %s instance", - value->ob_type->tp_name); + if (x == -1 && PyErr_Occurred()) return NULL; - } memcpy(ptr, &x, sizeof(long double)); _RET(value); } @@ -1026,12 +1022,8 @@ d_set(void *ptr, PyObject *value, Py_ssize_t size) double x; x = PyFloat_AsDouble(value); - if (x == -1 && PyErr_Occurred()) { - PyErr_Format(PyExc_TypeError, - " float expected instead of %s instance", - value->ob_type->tp_name); + if (x == -1 && PyErr_Occurred()) return NULL; - } memcpy(ptr, &x, sizeof(double)); _RET(value); } @@ -1050,12 +1042,8 @@ d_set_sw(void *ptr, PyObject *value, Py_ssize_t size) double x; x = PyFloat_AsDouble(value); - if (x == -1 && PyErr_Occurred()) { - PyErr_Format(PyExc_TypeError, - " float expected instead of %s instance", - value->ob_type->tp_name); + if (x == -1 && PyErr_Occurred()) return NULL; - } #ifdef WORDS_BIGENDIAN if (_PyFloat_Pack8(x, (unsigned char *)ptr, 1)) return NULL; @@ -1082,12 +1070,8 @@ f_set(void *ptr, PyObject *value, Py_ssize_t size) float x; x = (float)PyFloat_AsDouble(value); - if (x == -1 && PyErr_Occurred()) { - PyErr_Format(PyExc_TypeError, - " float expected instead of %s instance", - value->ob_type->tp_name); + if (x == -1 && PyErr_Occurred()) return NULL; - } memcpy(ptr, &x, sizeof(x)); _RET(value); } @@ -1106,12 +1090,8 @@ f_set_sw(void *ptr, PyObject *value, Py_ssize_t size) float x; x = (float)PyFloat_AsDouble(value); - if (x == -1 && PyErr_Occurred()) { - PyErr_Format(PyExc_TypeError, - " float expected instead of %s instance", - value->ob_type->tp_name); + if (x == -1 && PyErr_Occurred()) return NULL; - } #ifdef WORDS_BIGENDIAN if (_PyFloat_Pack4(x, (unsigned char *)ptr, 1)) return NULL; |