]> granicus.if.org Git - python/commitdiff
Add keyword arg support to itertools.repeat().
authorRaymond Hettinger <python@rcn.com>
Thu, 19 Feb 2009 02:44:01 +0000 (02:44 +0000)
committerRaymond Hettinger <python@rcn.com>
Thu, 19 Feb 2009 02:44:01 +0000 (02:44 +0000)
Lib/test/test_itertools.py
Modules/itertoolsmodule.c

index 94159b5d0e6c28b55f64b8350ddc90d4e94aaaeb..84924843a39437a6116585984175afea6c32ceae 100644 (file)
@@ -640,6 +640,7 @@ class TestBasicOps(unittest.TestCase):
         self.assertNotEqual(len(set(map(id, list(product('abc', 'def'))))), 1)
 
     def test_repeat(self):
+        self.assertEqual(list(repeat(object='a', times=3)), ['a', 'a', 'a'])
         self.assertEqual(lzip(range(3),repeat('a')),
                          [(0, 'a'), (1, 'a'), (2, 'a')])
         self.assertEqual(list(repeat('a', 3)), ['a', 'a', 'a'])
index e2ca9c74b71c5d91c0bbaf37b69fc8e557dabc97..48dffe5e6ac9376d37648a0aff78239b08e887ed 100644 (file)
@@ -3106,11 +3106,10 @@ repeat_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
        repeatobject *ro;
        PyObject *element;
        Py_ssize_t cnt = -1;
-
-       if (type == &repeat_type && !_PyArg_NoKeywords("repeat()", kwds))
-               return NULL;
-
-       if (!PyArg_ParseTuple(args, "O|n:repeat", &element, &cnt))
+       static char *kwargs[] = {"object", "times", NULL};
+       if (!PyArg_ParseTupleAndKeywords(args, kwds, "O|n:repeat", kwargs, 
+                                        &element, &cnt))
                return NULL;
 
        if (PyTuple_Size(args) == 2 && cnt < 0)
@@ -3178,8 +3177,8 @@ static PyMethodDef repeat_methods[] = {
 };
 
 PyDoc_STRVAR(repeat_doc,
-"repeat(element [,times]) -> create an iterator which returns the element\n\
-for the specified number of times.  If not specified, returns the element\n\
+"repeat(object [,times]) -> create an iterator which returns the object\n\
+for the specified number of times.  If not specified, returns the object\n\
 endlessly.");
 
 static PyTypeObject repeat_type = {