Commit 602d8db2 authored by Alexandre Vassalotti's avatar Alexandre Vassalotti

Added better pickling support to xrange objects.

Cleaned up the unit test.
parent 1f2f61a7
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
import test.test_support, unittest import test.test_support, unittest
import sys import sys
import pickle
import warnings import warnings
warnings.filterwarnings("ignore", "integer argument expected", warnings.filterwarnings("ignore", "integer argument expected",
...@@ -57,15 +58,15 @@ class XrangeTest(unittest.TestCase): ...@@ -57,15 +58,15 @@ class XrangeTest(unittest.TestCase):
self.assertEqual(len(r), sys.maxint) self.assertEqual(len(r), sys.maxint)
self.assertRaises(OverflowError, xrange, -sys.maxint-1, sys.maxint, 2) self.assertRaises(OverflowError, xrange, -sys.maxint-1, sys.maxint, 2)
def test_getnewargs(self): def test_pickling(self):
def test(*args): testcases = [(13,), (0, 11), (-22, 10), (20, 3, -1),
r = xrange(*args) (13, 21, 3), (-2, 2, 2)]
return list(r) == list(xrange(*r.__getnewargs__())) for proto in range(pickle.HIGHEST_PROTOCOL):
tests = [(13,), (0, 11), (-22, 10), (20, 3, -1), for t in testcases:
(13, 21, 3), (-2, 2, 2)] r = xrange(*t)
for t in tests: self.assertEquals(list(pickle.loads(pickle.dumps(r, proto))),
self.assert_(test(*t), list(r))
"xrange.__getnewargs__() failed with %r" % (t,))
def test_main(): def test_main():
test.test_support.run_unittest(XrangeTest) test.test_support.run_unittest(XrangeTest)
......
...@@ -131,9 +131,9 @@ range_repr(rangeobject *r) ...@@ -131,9 +131,9 @@ range_repr(rangeobject *r)
/* Pickling support */ /* Pickling support */
static PyObject * static PyObject *
range_getnewargs(rangeobject *r) range_reduce(rangeobject *r, PyObject *args)
{ {
return Py_BuildValue("(iii)", return Py_BuildValue("(O(iii))", Py_TYPE(r),
r->start, r->start,
r->start + r->len * r->step, r->start + r->len * r->step,
r->step); r->step);
...@@ -155,7 +155,7 @@ PyDoc_STRVAR(reverse_doc, ...@@ -155,7 +155,7 @@ PyDoc_STRVAR(reverse_doc,
static PyMethodDef range_methods[] = { static PyMethodDef range_methods[] = {
{"__reversed__", (PyCFunction)range_reverse, METH_NOARGS, reverse_doc}, {"__reversed__", (PyCFunction)range_reverse, METH_NOARGS, reverse_doc},
{"__getnewargs__", (PyCFunction)range_getnewargs, METH_NOARGS}, {"__reduce__", (PyCFunction)range_reduce, METH_VARARGS},
{NULL, NULL} /* sentinel */ {NULL, NULL} /* sentinel */
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment