summaryrefslogtreecommitdiffstats
path: root/Modules/_io
diff options
context:
space:
mode:
authorXiang Zhang <angwerzx@126.com>2017-04-15 04:47:28 (GMT)
committerGitHub <noreply@github.com>2017-04-15 04:47:28 (GMT)
commit026435ce49419a3366171416c68114dd8a1144c7 (patch)
treebc20a7681507de85662e789a3331b3a048bdaed6 /Modules/_io
parenteaeda64c2fd2abd33e59b03298f9cdc9e8efef89 (diff)
downloadcpython-026435ce49419a3366171416c68114dd8a1144c7.zip
cpython-026435ce49419a3366171416c68114dd8a1144c7.tar.gz
cpython-026435ce49419a3366171416c68114dd8a1144c7.tar.bz2
bpo-30068: add missing iter(self) in _io._IOBase.readlines when hint is present (#1130)
Diffstat (limited to 'Modules/_io')
-rw-r--r--Modules/_io/iobase.c25
1 files changed, 17 insertions, 8 deletions
diff --git a/Modules/_io/iobase.c b/Modules/_io/iobase.c
index 75cfe59..1a687c5 100644
--- a/Modules/_io/iobase.c
+++ b/Modules/_io/iobase.c
@@ -643,7 +643,7 @@ _io__IOBase_readlines_impl(PyObject *self, Py_ssize_t hint)
/*[clinic end generated code: output=2f50421677fa3dea input=9400c786ea9dc416]*/
{
Py_ssize_t length = 0;
- PyObject *result;
+ PyObject *result, *it = NULL;
result = PyList_New(0);
if (result == NULL)
@@ -658,19 +658,22 @@ _io__IOBase_readlines_impl(PyObject *self, Py_ssize_t hint)
self, NULL);
if (ret == NULL) {
- Py_DECREF(result);
- return NULL;
+ goto error;
}
Py_DECREF(ret);
return result;
}
+ it = PyObject_GetIter(self);
+ if (it == NULL) {
+ goto error;
+ }
+
while (1) {
- PyObject *line = PyIter_Next(self);
+ PyObject *line = PyIter_Next(it);
if (line == NULL) {
if (PyErr_Occurred()) {
- Py_DECREF(result);
- return NULL;
+ goto error;
}
else
break; /* StopIteration raised */
@@ -678,8 +681,7 @@ _io__IOBase_readlines_impl(PyObject *self, Py_ssize_t hint)
if (PyList_Append(result, line) < 0) {
Py_DECREF(line);
- Py_DECREF(result);
- return NULL;
+ goto error;
}
length += PyObject_Size(line);
Py_DECREF(line);
@@ -687,7 +689,14 @@ _io__IOBase_readlines_impl(PyObject *self, Py_ssize_t hint)
if (length > hint)
break;
}
+
+ Py_DECREF(it);
return result;
+
+ error:
+ Py_XDECREF(it);
+ Py_DECREF(result);
+ return NULL;
}
/*[clinic input]