| Guido van Rossum | 7dab242 | 2002-04-26 19:40:56 +0000 | [diff] [blame] | 1 | /* enumerate object */ | 
|  | 2 |  | 
|  | 3 | #include "Python.h" | 
|  | 4 |  | 
|  | 5 | typedef struct { | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 6 | PyObject_HEAD | 
|  | 7 | Py_ssize_t en_index;           /* current index of enumeration */ | 
|  | 8 | PyObject* en_sit;          /* secondary iterator of enumeration */ | 
|  | 9 | PyObject* en_result;           /* result tuple  */ | 
|  | 10 | PyObject* en_longindex;        /* index for sequences >= PY_SSIZE_T_MAX */ | 
| Guido van Rossum | 7dab242 | 2002-04-26 19:40:56 +0000 | [diff] [blame] | 11 | } enumobject; | 
|  | 12 |  | 
| Guido van Rossum | 7dab242 | 2002-04-26 19:40:56 +0000 | [diff] [blame] | 13 | static PyObject * | 
|  | 14 | enum_new(PyTypeObject *type, PyObject *args, PyObject *kwds) | 
|  | 15 | { | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 16 | enumobject *en; | 
|  | 17 | PyObject *seq = NULL; | 
|  | 18 | PyObject *start = NULL; | 
|  | 19 | static char *kwlist[] = {"iterable", "start", 0}; | 
| Guido van Rossum | 7dab242 | 2002-04-26 19:40:56 +0000 | [diff] [blame] | 20 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 21 | if (!PyArg_ParseTupleAndKeywords(args, kwds, "O|O:enumerate", kwlist, | 
|  | 22 | &seq, &start)) | 
|  | 23 | return NULL; | 
| Guido van Rossum | 7dab242 | 2002-04-26 19:40:56 +0000 | [diff] [blame] | 24 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 25 | en = (enumobject *)type->tp_alloc(type, 0); | 
|  | 26 | if (en == NULL) | 
|  | 27 | return NULL; | 
|  | 28 | if (start != NULL) { | 
|  | 29 | start = PyNumber_Index(start); | 
|  | 30 | if (start == NULL) { | 
|  | 31 | Py_DECREF(en); | 
|  | 32 | return NULL; | 
|  | 33 | } | 
|  | 34 | assert(PyLong_Check(start)); | 
|  | 35 | en->en_index = PyLong_AsSsize_t(start); | 
|  | 36 | if (en->en_index == -1 && PyErr_Occurred()) { | 
|  | 37 | PyErr_Clear(); | 
|  | 38 | en->en_index = PY_SSIZE_T_MAX; | 
|  | 39 | en->en_longindex = start; | 
|  | 40 | } else { | 
|  | 41 | en->en_longindex = NULL; | 
|  | 42 | Py_DECREF(start); | 
|  | 43 | } | 
|  | 44 | } else { | 
|  | 45 | en->en_index = 0; | 
|  | 46 | en->en_longindex = NULL; | 
|  | 47 | } | 
|  | 48 | en->en_sit = PyObject_GetIter(seq); | 
|  | 49 | if (en->en_sit == NULL) { | 
|  | 50 | Py_DECREF(en); | 
|  | 51 | return NULL; | 
|  | 52 | } | 
|  | 53 | en->en_result = PyTuple_Pack(2, Py_None, Py_None); | 
|  | 54 | if (en->en_result == NULL) { | 
|  | 55 | Py_DECREF(en); | 
|  | 56 | return NULL; | 
|  | 57 | } | 
|  | 58 | return (PyObject *)en; | 
| Guido van Rossum | 7dab242 | 2002-04-26 19:40:56 +0000 | [diff] [blame] | 59 | } | 
|  | 60 |  | 
|  | 61 | static void | 
|  | 62 | enum_dealloc(enumobject *en) | 
|  | 63 | { | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 64 | PyObject_GC_UnTrack(en); | 
|  | 65 | Py_XDECREF(en->en_sit); | 
|  | 66 | Py_XDECREF(en->en_result); | 
|  | 67 | Py_XDECREF(en->en_longindex); | 
|  | 68 | Py_TYPE(en)->tp_free(en); | 
| Guido van Rossum | 7dab242 | 2002-04-26 19:40:56 +0000 | [diff] [blame] | 69 | } | 
|  | 70 |  | 
|  | 71 | static int | 
|  | 72 | enum_traverse(enumobject *en, visitproc visit, void *arg) | 
|  | 73 | { | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 74 | Py_VISIT(en->en_sit); | 
|  | 75 | Py_VISIT(en->en_result); | 
|  | 76 | Py_VISIT(en->en_longindex); | 
|  | 77 | return 0; | 
| Guido van Rossum | 7dab242 | 2002-04-26 19:40:56 +0000 | [diff] [blame] | 78 | } | 
|  | 79 |  | 
|  | 80 | static PyObject * | 
| Guido van Rossum | 8ce8a78 | 2007-11-01 19:42:39 +0000 | [diff] [blame] | 81 | enum_next_long(enumobject *en, PyObject* next_item) | 
|  | 82 | { | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 83 | static PyObject *one = NULL; | 
|  | 84 | PyObject *result = en->en_result; | 
|  | 85 | PyObject *next_index; | 
|  | 86 | PyObject *stepped_up; | 
| Guido van Rossum | 8ce8a78 | 2007-11-01 19:42:39 +0000 | [diff] [blame] | 87 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 88 | if (en->en_longindex == NULL) { | 
|  | 89 | en->en_longindex = PyLong_FromSsize_t(PY_SSIZE_T_MAX); | 
|  | 90 | if (en->en_longindex == NULL) | 
|  | 91 | return NULL; | 
|  | 92 | } | 
|  | 93 | if (one == NULL) { | 
|  | 94 | one = PyLong_FromLong(1); | 
|  | 95 | if (one == NULL) | 
|  | 96 | return NULL; | 
|  | 97 | } | 
|  | 98 | next_index = en->en_longindex; | 
|  | 99 | assert(next_index != NULL); | 
|  | 100 | stepped_up = PyNumber_Add(next_index, one); | 
|  | 101 | if (stepped_up == NULL) | 
|  | 102 | return NULL; | 
|  | 103 | en->en_longindex = stepped_up; | 
| Guido van Rossum | 8ce8a78 | 2007-11-01 19:42:39 +0000 | [diff] [blame] | 104 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 105 | if (result->ob_refcnt == 1) { | 
|  | 106 | Py_INCREF(result); | 
|  | 107 | Py_DECREF(PyTuple_GET_ITEM(result, 0)); | 
|  | 108 | Py_DECREF(PyTuple_GET_ITEM(result, 1)); | 
|  | 109 | } else { | 
|  | 110 | result = PyTuple_New(2); | 
|  | 111 | if (result == NULL) { | 
|  | 112 | Py_DECREF(next_index); | 
|  | 113 | Py_DECREF(next_item); | 
|  | 114 | return NULL; | 
|  | 115 | } | 
|  | 116 | } | 
|  | 117 | PyTuple_SET_ITEM(result, 0, next_index); | 
|  | 118 | PyTuple_SET_ITEM(result, 1, next_item); | 
|  | 119 | return result; | 
| Guido van Rossum | 8ce8a78 | 2007-11-01 19:42:39 +0000 | [diff] [blame] | 120 | } | 
|  | 121 |  | 
|  | 122 | static PyObject * | 
| Guido van Rossum | 7dab242 | 2002-04-26 19:40:56 +0000 | [diff] [blame] | 123 | enum_next(enumobject *en) | 
|  | 124 | { | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 125 | PyObject *next_index; | 
|  | 126 | PyObject *next_item; | 
|  | 127 | PyObject *result = en->en_result; | 
|  | 128 | PyObject *it = en->en_sit; | 
| Guido van Rossum | 7dab242 | 2002-04-26 19:40:56 +0000 | [diff] [blame] | 129 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 130 | next_item = (*Py_TYPE(it)->tp_iternext)(it); | 
|  | 131 | if (next_item == NULL) | 
|  | 132 | return NULL; | 
| Guido van Rossum | ca5ed5b | 2002-07-16 21:02:42 +0000 | [diff] [blame] | 133 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 134 | if (en->en_index == PY_SSIZE_T_MAX) | 
|  | 135 | return enum_next_long(en, next_item); | 
| Guido van Rossum | 8ce8a78 | 2007-11-01 19:42:39 +0000 | [diff] [blame] | 136 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 137 | next_index = PyLong_FromSsize_t(en->en_index); | 
|  | 138 | if (next_index == NULL) { | 
|  | 139 | Py_DECREF(next_item); | 
|  | 140 | return NULL; | 
|  | 141 | } | 
|  | 142 | en->en_index++; | 
| Raymond Hettinger | e8b0f04 | 2003-05-28 14:05:34 +0000 | [diff] [blame] | 143 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 144 | if (result->ob_refcnt == 1) { | 
|  | 145 | Py_INCREF(result); | 
|  | 146 | Py_DECREF(PyTuple_GET_ITEM(result, 0)); | 
|  | 147 | Py_DECREF(PyTuple_GET_ITEM(result, 1)); | 
|  | 148 | } else { | 
|  | 149 | result = PyTuple_New(2); | 
|  | 150 | if (result == NULL) { | 
|  | 151 | Py_DECREF(next_index); | 
|  | 152 | Py_DECREF(next_item); | 
|  | 153 | return NULL; | 
|  | 154 | } | 
|  | 155 | } | 
|  | 156 | PyTuple_SET_ITEM(result, 0, next_index); | 
|  | 157 | PyTuple_SET_ITEM(result, 1, next_item); | 
|  | 158 | return result; | 
| Guido van Rossum | 7dab242 | 2002-04-26 19:40:56 +0000 | [diff] [blame] | 159 | } | 
|  | 160 |  | 
| Martin v. Löwis | 14f8b4c | 2002-06-13 20:33:02 +0000 | [diff] [blame] | 161 | PyDoc_STRVAR(enum_doc, | 
| Jeremy Hylton | fbbe347 | 2003-04-21 20:26:25 +0000 | [diff] [blame] | 162 | "enumerate(iterable) -> iterator for index, value of iterable\n" | 
|  | 163 | "\n" | 
| Ezio Melotti | a3e61a4 | 2009-09-25 16:14:31 +0000 | [diff] [blame] | 164 | "Return an enumerate object.  iterable must be another object that supports\n" | 
| Jeremy Hylton | fbbe347 | 2003-04-21 20:26:25 +0000 | [diff] [blame] | 165 | "iteration.  The enumerate object yields pairs containing a count (from\n" | 
|  | 166 | "zero) and a value yielded by the iterable argument.  enumerate is useful\n" | 
|  | 167 | "for obtaining an indexed list: (0, seq[0]), (1, seq[1]), (2, seq[2]), ..."); | 
| Guido van Rossum | 7dab242 | 2002-04-26 19:40:56 +0000 | [diff] [blame] | 168 |  | 
|  | 169 | PyTypeObject PyEnum_Type = { | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 170 | PyVarObject_HEAD_INIT(&PyType_Type, 0) | 
|  | 171 | "enumerate",                    /* tp_name */ | 
|  | 172 | sizeof(enumobject),             /* tp_basicsize */ | 
|  | 173 | 0,                              /* tp_itemsize */ | 
|  | 174 | /* methods */ | 
|  | 175 | (destructor)enum_dealloc,       /* tp_dealloc */ | 
|  | 176 | 0,                              /* tp_print */ | 
|  | 177 | 0,                              /* tp_getattr */ | 
|  | 178 | 0,                              /* tp_setattr */ | 
|  | 179 | 0,                              /* tp_reserved */ | 
|  | 180 | 0,                              /* tp_repr */ | 
|  | 181 | 0,                              /* tp_as_number */ | 
|  | 182 | 0,                              /* tp_as_sequence */ | 
|  | 183 | 0,                              /* tp_as_mapping */ | 
|  | 184 | 0,                              /* tp_hash */ | 
|  | 185 | 0,                              /* tp_call */ | 
|  | 186 | 0,                              /* tp_str */ | 
|  | 187 | PyObject_GenericGetAttr,        /* tp_getattro */ | 
|  | 188 | 0,                              /* tp_setattro */ | 
|  | 189 | 0,                              /* tp_as_buffer */ | 
|  | 190 | Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_GC | | 
|  | 191 | Py_TPFLAGS_BASETYPE,    /* tp_flags */ | 
|  | 192 | enum_doc,                       /* tp_doc */ | 
|  | 193 | (traverseproc)enum_traverse,    /* tp_traverse */ | 
|  | 194 | 0,                              /* tp_clear */ | 
|  | 195 | 0,                              /* tp_richcompare */ | 
|  | 196 | 0,                              /* tp_weaklistoffset */ | 
|  | 197 | PyObject_SelfIter,                  /* tp_iter */ | 
|  | 198 | (iternextfunc)enum_next,        /* tp_iternext */ | 
|  | 199 | 0,                              /* tp_methods */ | 
|  | 200 | 0,                              /* tp_members */ | 
|  | 201 | 0,                              /* tp_getset */ | 
|  | 202 | 0,                              /* tp_base */ | 
|  | 203 | 0,                              /* tp_dict */ | 
|  | 204 | 0,                              /* tp_descr_get */ | 
|  | 205 | 0,                              /* tp_descr_set */ | 
|  | 206 | 0,                              /* tp_dictoffset */ | 
|  | 207 | 0,                              /* tp_init */ | 
|  | 208 | PyType_GenericAlloc,            /* tp_alloc */ | 
|  | 209 | enum_new,                       /* tp_new */ | 
|  | 210 | PyObject_GC_Del,                /* tp_free */ | 
| Guido van Rossum | 7dab242 | 2002-04-26 19:40:56 +0000 | [diff] [blame] | 211 | }; | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 212 |  | 
|  | 213 | /* Reversed Object ***************************************************************/ | 
|  | 214 |  | 
|  | 215 | typedef struct { | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 216 | PyObject_HEAD | 
|  | 217 | Py_ssize_t      index; | 
|  | 218 | PyObject* seq; | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 219 | } reversedobject; | 
|  | 220 |  | 
|  | 221 | static PyObject * | 
|  | 222 | reversed_new(PyTypeObject *type, PyObject *args, PyObject *kwds) | 
|  | 223 | { | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 224 | Py_ssize_t n; | 
|  | 225 | PyObject *seq, *reversed_meth; | 
|  | 226 | static PyObject *reversed_cache = NULL; | 
|  | 227 | reversedobject *ro; | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 228 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 229 | if (type == &PyReversed_Type && !_PyArg_NoKeywords("reversed()", kwds)) | 
|  | 230 | return NULL; | 
| Alexandre Vassalotti | bee3253 | 2008-05-16 18:15:12 +0000 | [diff] [blame] | 231 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 232 | if (!PyArg_UnpackTuple(args, "reversed", 1, 1, &seq) ) | 
|  | 233 | return NULL; | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 234 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 235 | reversed_meth = _PyObject_LookupSpecial(seq, "__reversed__", &reversed_cache); | 
|  | 236 | if (reversed_meth != NULL) { | 
|  | 237 | PyObject *res = PyObject_CallFunctionObjArgs(reversed_meth, NULL); | 
|  | 238 | Py_DECREF(reversed_meth); | 
|  | 239 | return res; | 
|  | 240 | } | 
|  | 241 | else if (PyErr_Occurred()) | 
|  | 242 | return NULL; | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 243 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 244 | if (!PySequence_Check(seq)) { | 
|  | 245 | PyErr_SetString(PyExc_TypeError, | 
|  | 246 | "argument to reversed() must be a sequence"); | 
|  | 247 | return NULL; | 
|  | 248 | } | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 249 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 250 | n = PySequence_Size(seq); | 
|  | 251 | if (n == -1) | 
|  | 252 | return NULL; | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 253 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 254 | ro = (reversedobject *)type->tp_alloc(type, 0); | 
|  | 255 | if (ro == NULL) | 
|  | 256 | return NULL; | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 257 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 258 | ro->index = n-1; | 
|  | 259 | Py_INCREF(seq); | 
|  | 260 | ro->seq = seq; | 
|  | 261 | return (PyObject *)ro; | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 262 | } | 
|  | 263 |  | 
|  | 264 | static void | 
|  | 265 | reversed_dealloc(reversedobject *ro) | 
|  | 266 | { | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 267 | PyObject_GC_UnTrack(ro); | 
|  | 268 | Py_XDECREF(ro->seq); | 
|  | 269 | Py_TYPE(ro)->tp_free(ro); | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 270 | } | 
|  | 271 |  | 
|  | 272 | static int | 
|  | 273 | reversed_traverse(reversedobject *ro, visitproc visit, void *arg) | 
|  | 274 | { | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 275 | Py_VISIT(ro->seq); | 
|  | 276 | return 0; | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 277 | } | 
|  | 278 |  | 
|  | 279 | static PyObject * | 
|  | 280 | reversed_next(reversedobject *ro) | 
|  | 281 | { | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 282 | PyObject *item; | 
|  | 283 | Py_ssize_t index = ro->index; | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 284 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 285 | if (index >= 0) { | 
|  | 286 | item = PySequence_GetItem(ro->seq, index); | 
|  | 287 | if (item != NULL) { | 
|  | 288 | ro->index--; | 
|  | 289 | return item; | 
|  | 290 | } | 
|  | 291 | if (PyErr_ExceptionMatches(PyExc_IndexError) || | 
|  | 292 | PyErr_ExceptionMatches(PyExc_StopIteration)) | 
|  | 293 | PyErr_Clear(); | 
|  | 294 | } | 
|  | 295 | ro->index = -1; | 
|  | 296 | Py_CLEAR(ro->seq); | 
|  | 297 | return NULL; | 
| Raymond Hettinger | 029dba5 | 2004-02-10 09:33:39 +0000 | [diff] [blame] | 298 | } | 
|  | 299 |  | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 300 | PyDoc_STRVAR(reversed_doc, | 
| Raymond Hettinger | d2afee4 | 2004-08-25 19:42:12 +0000 | [diff] [blame] | 301 | "reversed(sequence) -> reverse iterator over values of the sequence\n" | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 302 | "\n" | 
|  | 303 | "Return a reverse iterator"); | 
|  | 304 |  | 
| Raymond Hettinger | 6b27cda | 2005-09-24 21:23:05 +0000 | [diff] [blame] | 305 | static PyObject * | 
| Raymond Hettinger | ef9bf40 | 2004-03-10 10:10:42 +0000 | [diff] [blame] | 306 | reversed_len(reversedobject *ro) | 
|  | 307 | { | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 308 | Py_ssize_t position, seqsize; | 
| Raymond Hettinger | 7892b1c | 2004-04-12 18:10:01 +0000 | [diff] [blame] | 309 |  | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 310 | if (ro->seq == NULL) | 
|  | 311 | return PyLong_FromLong(0); | 
|  | 312 | seqsize = PySequence_Size(ro->seq); | 
|  | 313 | if (seqsize == -1) | 
|  | 314 | return NULL; | 
|  | 315 | position = ro->index + 1; | 
|  | 316 | return PyLong_FromSsize_t((seqsize < position)  ?  0  :  position); | 
| Raymond Hettinger | ef9bf40 | 2004-03-10 10:10:42 +0000 | [diff] [blame] | 317 | } | 
|  | 318 |  | 
| Armin Rigo | f5b3e36 | 2006-02-11 21:32:43 +0000 | [diff] [blame] | 319 | PyDoc_STRVAR(length_hint_doc, "Private method returning an estimate of len(list(it))."); | 
| Raymond Hettinger | 6b27cda | 2005-09-24 21:23:05 +0000 | [diff] [blame] | 320 |  | 
|  | 321 | static PyMethodDef reversediter_methods[] = { | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 322 | {"__length_hint__", (PyCFunction)reversed_len, METH_NOARGS, length_hint_doc}, | 
|  | 323 | {NULL,              NULL}           /* sentinel */ | 
| Raymond Hettinger | 06353f7 | 2004-02-08 10:49:42 +0000 | [diff] [blame] | 324 | }; | 
|  | 325 |  | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 326 | PyTypeObject PyReversed_Type = { | 
| Antoine Pitrou | 7f14f0d | 2010-05-09 16:14:21 +0000 | [diff] [blame] | 327 | PyVarObject_HEAD_INIT(&PyType_Type, 0) | 
|  | 328 | "reversed",                     /* tp_name */ | 
|  | 329 | sizeof(reversedobject),         /* tp_basicsize */ | 
|  | 330 | 0,                              /* tp_itemsize */ | 
|  | 331 | /* methods */ | 
|  | 332 | (destructor)reversed_dealloc,   /* tp_dealloc */ | 
|  | 333 | 0,                              /* tp_print */ | 
|  | 334 | 0,                              /* tp_getattr */ | 
|  | 335 | 0,                              /* tp_setattr */ | 
|  | 336 | 0,                              /* tp_reserved */ | 
|  | 337 | 0,                              /* tp_repr */ | 
|  | 338 | 0,                              /* tp_as_number */ | 
|  | 339 | 0,                                  /* tp_as_sequence */ | 
|  | 340 | 0,                              /* tp_as_mapping */ | 
|  | 341 | 0,                              /* tp_hash */ | 
|  | 342 | 0,                              /* tp_call */ | 
|  | 343 | 0,                              /* tp_str */ | 
|  | 344 | PyObject_GenericGetAttr,        /* tp_getattro */ | 
|  | 345 | 0,                              /* tp_setattro */ | 
|  | 346 | 0,                              /* tp_as_buffer */ | 
|  | 347 | Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_GC | | 
|  | 348 | Py_TPFLAGS_BASETYPE,    /* tp_flags */ | 
|  | 349 | reversed_doc,                   /* tp_doc */ | 
|  | 350 | (traverseproc)reversed_traverse,/* tp_traverse */ | 
|  | 351 | 0,                              /* tp_clear */ | 
|  | 352 | 0,                              /* tp_richcompare */ | 
|  | 353 | 0,                              /* tp_weaklistoffset */ | 
|  | 354 | PyObject_SelfIter,                  /* tp_iter */ | 
|  | 355 | (iternextfunc)reversed_next,    /* tp_iternext */ | 
|  | 356 | reversediter_methods,               /* tp_methods */ | 
|  | 357 | 0,                              /* tp_members */ | 
|  | 358 | 0,                              /* tp_getset */ | 
|  | 359 | 0,                              /* tp_base */ | 
|  | 360 | 0,                              /* tp_dict */ | 
|  | 361 | 0,                              /* tp_descr_get */ | 
|  | 362 | 0,                              /* tp_descr_set */ | 
|  | 363 | 0,                              /* tp_dictoffset */ | 
|  | 364 | 0,                              /* tp_init */ | 
|  | 365 | PyType_GenericAlloc,            /* tp_alloc */ | 
|  | 366 | reversed_new,                   /* tp_new */ | 
|  | 367 | PyObject_GC_Del,                /* tp_free */ | 
| Raymond Hettinger | 85c20a4 | 2003-11-06 14:06:48 +0000 | [diff] [blame] | 368 | }; |