]> granicus.if.org Git - python/commitdiff
Added better pickling support to xrange objects.
authorAlexandre Vassalotti <alexandre@peadrop.com>
Tue, 10 Jun 2008 04:01:23 +0000 (04:01 +0000)
committerAlexandre Vassalotti <alexandre@peadrop.com>
Tue, 10 Jun 2008 04:01:23 +0000 (04:01 +0000)
Cleaned up the unit test.

Lib/test/test_xrange.py
Objects/rangeobject.c

index ab68c3621c775226ef1c07b5cbbe2c2c0615e16e..7a2eea552d6559930d71d3ad218a96ff2b5ed496 100644 (file)
@@ -2,6 +2,7 @@
 
 import test.test_support, unittest
 import sys
+import pickle
 
 import warnings
 warnings.filterwarnings("ignore", "integer argument expected",
@@ -57,15 +58,15 @@ class XrangeTest(unittest.TestCase):
         self.assertEqual(len(r), sys.maxint)
         self.assertRaises(OverflowError, xrange, -sys.maxint-1, sys.maxint, 2)
 
-    def test_getnewargs(self):
-        def test(*args):
-            r = xrange(*args)
-            return list(r) == list(xrange(*r.__getnewargs__()))
-        tests = [(13,), (0, 11), (-22, 10), (20, 3, -1),
-                 (13, 21, 3), (-2, 2, 2)]
-        for t in tests:
-            self.assert_(test(*t),
-                         "xrange.__getnewargs__() failed with %r" % (t,))
+    def test_pickling(self):
+        testcases = [(13,), (0, 11), (-22, 10), (20, 3, -1),
+                     (13, 21, 3), (-2, 2, 2)]
+        for proto in range(pickle.HIGHEST_PROTOCOL):
+            for t in testcases:
+                r = xrange(*t)
+                self.assertEquals(list(pickle.loads(pickle.dumps(r, proto))),
+                                  list(r))
+
 
 def test_main():
     test.test_support.run_unittest(XrangeTest)
index bfc038ed2db909d58f49d764f6fa54f4fab5d243..76d384914e52adbc255f48e8b2d345c094a475c8 100644 (file)
@@ -131,9 +131,9 @@ range_repr(rangeobject *r)
 
 /* Pickling support */
 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->len * r->step,
                             r->step);
@@ -155,7 +155,7 @@ PyDoc_STRVAR(reverse_doc,
 
 static PyMethodDef range_methods[] = {
        {"__reversed__",        (PyCFunction)range_reverse, METH_NOARGS, reverse_doc},
-       {"__getnewargs__",      (PyCFunction)range_getnewargs, METH_NOARGS},
+       {"__reduce__",          (PyCFunction)range_reduce, METH_VARARGS},
        {NULL,          NULL}           /* sentinel */
 };