이터레이터 프로토콜
*******************

특히 이터레이터를 사용하기 위한 두 함수가 있습니다.

int PyIter_Check(PyObject *o)

   객체 *o*가 이터레이터 프로토콜을 지원하면 참을 돌려줍니다.

PyObject* PyIter_Next(PyObject *o)
    *Return value: New reference.*

   Return the next value from the iteration *o*.  The object must be
   an iterator (it is up to the caller to check this).  If there are
   no remaining values, returns "NULL" with no exception set.  If an
   error occurs while retrieving the item, returns "NULL" and passes
   along the exception.

이터레이터를 이터레이트하는 루프를 작성하려면, C 코드는 이런 식으로 되
어야 합니다:

   PyObject *iterator = PyObject_GetIter(obj);
   PyObject *item;

   if (iterator == NULL) {
       /* propagate error */
   }

   while ((item = PyIter_Next(iterator))) {
       /* do something with item */
       ...
       /* release reference when done */
       Py_DECREF(item);
   }

   Py_DECREF(iterator);

   if (PyErr_Occurred()) {
       /* propagate error */
   }
   else {
       /* continue doing useful work */
   }
