1 .. highlightlang:: c 2 3 .. _iterator: 4 5 Iterator Protocol 6 ================= 7 8 .. versionadded:: 2.2 9 10 There are two functions specifically for working with iterators. 11 12 13 .. c:function:: int PyIter_Check(PyObject *o) 14 15 Return true if the object *o* supports the iterator protocol. 16 17 This function can return a false positive in the case of old-style 18 classes because those classes always define a :c:member:`tp_iternext` 19 slot with logic that either invokes a :meth:`next` method or raises 20 a :exc:`TypeError`. 21 22 .. c:function:: PyObject* PyIter_Next(PyObject *o) 23 24 Return the next value from the iteration *o*. The object must be an iterator 25 (it is up to the caller to check this). If there are no remaining values, 26 returns *NULL* with no exception set. If an error occurs while retrieving 27 the item, returns *NULL* and passes along the exception. 28 29 To write a loop which iterates over an iterator, the C code should look 30 something like this:: 31 32 PyObject *iterator = PyObject_GetIter(obj); 33 PyObject *item; 34 35 if (iterator == NULL) { 36 /* propagate error */ 37 } 38 39 while (item = PyIter_Next(iterator)) { 40 /* do something with item */ 41 ... 42 /* release reference when done */ 43 Py_DECREF(item); 44 } 45 46 Py_DECREF(iterator); 47 48 if (PyErr_Occurred()) { 49 /* propagate error */ 50 } 51 else { 52 /* continue doing useful work */ 53 } 54