summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKristján Valur Jónsson <kristjan@ccpgames.com>2014-03-04 23:19:24 (GMT)
committerKristján Valur Jónsson <kristjan@ccpgames.com>2014-03-04 23:19:24 (GMT)
commit4ca688edeb07de955e1ef67c11f0e327f12ffa6e (patch)
tree27fa902c07258b5749d0984566d7df4ba73d740d
parent682ea5f70e5450ffd5a50ef7f39d65c2faeb6b63 (diff)
downloadcpython-4ca688edeb07de955e1ef67c11f0e327f12ffa6e.zip
cpython-4ca688edeb07de955e1ef67c11f0e327f12ffa6e.tar.gz
cpython-4ca688edeb07de955e1ef67c11f0e327f12ffa6e.tar.bz2
Fix pickling of rangeiter. rangeiter_setstate would not allow setting it
to the exhausted state.
-rw-r--r--Lib/test/test_range.py12
-rw-r--r--Objects/rangeobject.c2
2 files changed, 13 insertions, 1 deletions
diff --git a/Lib/test/test_range.py b/Lib/test/test_range.py
index 2a13bfe..063f320 100644
--- a/Lib/test/test_range.py
+++ b/Lib/test/test_range.py
@@ -379,6 +379,18 @@ class RangeTest(unittest.TestCase):
it = pickle.loads(d)
self.assertEqual(list(it), data[1:])
+ def test_exhausted_iterator_pickling(self):
+ r = range(20)
+ i = iter(r)
+ while True:
+ r = next(i)
+ if r == 19:
+ break
+ d = pickle.dumps(i)
+ i2 = pickle.loads(d)
+ self.assertEqual(list(i), [])
+ self.assertEqual(list(i2), [])
+
def test_odd_bug(self):
# This used to raise a "SystemError: NULL result without error"
# because the range validation step was eating the exception
diff --git a/Objects/rangeobject.c b/Objects/rangeobject.c
index d790ca8..4b218b8 100644
--- a/Objects/rangeobject.c
+++ b/Objects/rangeobject.c
@@ -1000,7 +1000,7 @@ rangeiter_setstate(rangeiterobject *r, PyObject *state)
long index = PyLong_AsLong(state);
if (index == -1 && PyErr_Occurred())
return NULL;
- if (index < 0 || index >= r->len) {
+ if (index < 0 || index > r->len) {
PyErr_SetString(PyExc_ValueError, "index out of range");
return NULL;
}