| | cdef extern from "Python.h": |
| |
|
| | ############################################################################ |
| | # 6.5 Iterator Protocol |
| | ############################################################################ |
| | bint PyIter_Check(object o) |
| | # Return true if the object o supports the iterator protocol. |
| |
|
| | object PyIter_Next(object o) |
| | # Return value: New reference. |
| | # Return the next value from the iteration o. If the object is an |
| | # iterator, this retrieves the next value from the iteration, and |
| | # returns NULL with no exception set if there are no remaining |
| | # items. If the object is not an iterator, TypeError is raised, or |
| | # if there is an error in retrieving the item, returns NULL and |
| | # passes along the exception. |
| |
|
| | # To write a loop which iterates over an iterator, the C code should look something like this: |
| | # PyObject *iterator = PyObject_GetIter(obj); |
| | # PyObject *item; |
| | # if (iterator == NULL) { |
| | # |
| | # } |
| | # while (item = PyIter_Next(iterator)) { |
| | # |
| | # ... |
| | # |
| | # Py_DECREF(item); |
| | # } |
| | # Py_DECREF(iterator); |
| | # if (PyErr_Occurred()) { |
| | # |
| | # } |
| | # else { |
| | # |
| | # } |
| |
|