From: Hirokazu Yamamoto Date: Fri, 6 Mar 2009 03:04:07 +0000 (+0000) Subject: Issue #5334: array.fromfile() failed to insert values when EOFError was raised. X-Git-Tag: v3.1a1~12 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=54d0df69c0a57b5d5447f483494293354656c4fa;p=python Issue #5334: array.fromfile() failed to insert values when EOFError was raised. Reviewed by Benjamin Peterson. --- diff --git a/Lib/test/test_array.py b/Lib/test/test_array.py index c8698bb40e..8e228391bc 100755 --- a/Lib/test/test_array.py +++ b/Lib/test/test_array.py @@ -174,9 +174,8 @@ class BaseTest(unittest.TestCase): b.fromfile(f, len(self.example)) self.assertEqual(b, array.array(self.typecode, self.example)) self.assertNotEqual(a, b) - b.fromfile(f, len(self.example)) + self.assertRaises(EOFError, b.fromfile, f, len(self.example)+1) self.assertEqual(a, b) - self.assertRaises(EOFError, b.fromfile, f, 1) f.close() finally: if not f.closed: diff --git a/Misc/NEWS b/Misc/NEWS index 24b87291ef..f55944adb6 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -183,6 +183,8 @@ Core and Builtins Library ------- +- Issue #5334: array.fromfile() failed to insert values when EOFError was raised. + - Issue #5385: Fixed mmap crash after resize failure on windows. - Issue #5179: Fixed subprocess handle leak on failure on windows. diff --git a/Modules/arraymodule.c b/Modules/arraymodule.c index e55c2d0c9c..b39da8e963 100644 --- a/Modules/arraymodule.c +++ b/Modules/arraymodule.c @@ -1201,6 +1201,7 @@ array_fromfile(arrayobject *self, PyObject *args) PyObject *f, *b, *res; Py_ssize_t itemsize = self->ob_descr->itemsize; Py_ssize_t n, nbytes; + int not_enough_bytes; if (!PyArg_ParseTuple(args, "On:fromfile", &f, &n)) return NULL; @@ -1222,12 +1223,7 @@ array_fromfile(arrayobject *self, PyObject *args) return NULL; } - if (PyBytes_GET_SIZE(b) != nbytes) { - PyErr_SetString(PyExc_EOFError, - "read() didn't return enough bytes"); - Py_DECREF(b); - return NULL; - } + not_enough_bytes = (PyBytes_GET_SIZE(b) != nbytes); args = Py_BuildValue("(O)", b); Py_DECREF(b); @@ -1236,6 +1232,15 @@ array_fromfile(arrayobject *self, PyObject *args) res = array_fromstring(self, args); Py_DECREF(args); + if (res == NULL) + return NULL; + + if (not_enough_bytes) { + PyErr_SetString(PyExc_EOFError, + "read() didn't return enough bytes"); + Py_DECREF(res); + return NULL; + } return res; }