diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2016-03-06 12:02:26 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2016-03-06 12:02:26 (GMT) |
commit | 5608411a964f7fd5a35eda04b297e0d77de9958d (patch) | |
tree | b7dd9121e58f5660b8684477ee78377b6dc986cc | |
parent | b6bfce6c0b4721700241b550e31ae3aeabcb6f41 (diff) | |
parent | d55162517da38138fed130607b311ed4cc62ec77 (diff) | |
download | cpython-5608411a964f7fd5a35eda04b297e0d77de9958d.zip cpython-5608411a964f7fd5a35eda04b297e0d77de9958d.tar.gz cpython-5608411a964f7fd5a35eda04b297e0d77de9958d.tar.bz2 |
Issue #25718: Fixed pickling and copying the accumulate() iterator with total is None.
-rw-r--r-- | Lib/test/test_itertools.py | 10 | ||||
-rw-r--r-- | Misc/NEWS | 3 | ||||
-rw-r--r-- | Modules/itertoolsmodule.c | 17 |
3 files changed, 30 insertions, 0 deletions
diff --git a/Lib/test/test_itertools.py b/Lib/test/test_itertools.py index 9e55b2a..fab9b31 100644 --- a/Lib/test/test_itertools.py +++ b/Lib/test/test_itertools.py @@ -1448,6 +1448,16 @@ class TestExamples(unittest.TestCase): self.assertEqual(list(copy.deepcopy(it)), accumulated[1:]) self.assertEqual(list(copy.copy(it)), accumulated[1:]) + def test_accumulate_reducible_none(self): + # Issue #25718: total is None + it = accumulate([None, None, None], operator.is_) + self.assertEqual(next(it), None) + for proto in range(pickle.HIGHEST_PROTOCOL + 1): + it_copy = pickle.loads(pickle.dumps(it, proto)) + self.assertEqual(list(it_copy), [True, False]) + self.assertEqual(list(copy.deepcopy(it)), [True, False]) + self.assertEqual(list(copy.copy(it)), [True, False]) + def test_chain(self): self.assertEqual(''.join(chain('ABC', 'DEF')), 'ABCDEF') @@ -201,6 +201,9 @@ Core and Builtins Library ------- +- Issue #25718: Fixed pickling and copying the accumulate() iterator with + total is None. + - Issue #26475: Fixed debugging output for regular expressions with the (?x) flag. diff --git a/Modules/itertoolsmodule.c b/Modules/itertoolsmodule.c index 57eb4ec..9fb9d74 100644 --- a/Modules/itertoolsmodule.c +++ b/Modules/itertoolsmodule.c @@ -3464,6 +3464,23 @@ accumulate_next(accumulateobject *lz) static PyObject * accumulate_reduce(accumulateobject *lz) { + if (lz->total == Py_None) { + PyObject *it; + + if (PyType_Ready(&chain_type) < 0) + return NULL; + if (PyType_Ready(&islice_type) < 0) + return NULL; + it = PyObject_CallFunction((PyObject *)&chain_type, "(O)O", + lz->total, lz->it); + if (it == NULL) + return NULL; + it = PyObject_CallFunction((PyObject *)Py_TYPE(lz), "NO", + it, lz->binop ? lz->binop : Py_None); + if (it == NULL) + return NULL; + return Py_BuildValue("O(NiO)", &islice_type, it, 1, Py_None); + } return Py_BuildValue("O(OO)O", Py_TYPE(lz), lz->it, lz->binop?lz->binop:Py_None, lz->total?lz->total:Py_None); |