]> granicus.if.org Git - python/commit
Iterators phase 1. This comprises:
authorGuido van Rossum <guido@python.org>
Fri, 20 Apr 2001 19:13:02 +0000 (19:13 +0000)
committerGuido van Rossum <guido@python.org>
Fri, 20 Apr 2001 19:13:02 +0000 (19:13 +0000)
commit59d1d2b434e8cf79e8b1321f148254c68f56c1f7
tree7bbdfe6fcb9145d66de44e2085f4d085c95aea1e
parent12e73bb2f08db45fb92bf2aa57992424351be03d
Iterators phase 1.  This comprises:

new slot tp_iter in type object, plus new flag Py_TPFLAGS_HAVE_ITER
new C API PyObject_GetIter(), calls tp_iter
new builtin iter(), with two forms: iter(obj), and iter(function, sentinel)
new internal object types iterobject and calliterobject
new exception StopIteration
new opcodes for "for" loops, GET_ITER and FOR_ITER (also supported by dis.py)
new magic number for .pyc files
new special method for instances: __iter__() returns an iterator
iteration over dictionaries: "for x in dict" iterates over the keys
iteration over files: "for x in file" iterates over lines

TODO:

documentation
test suite
decide whether to use a different way to spell iter(function, sentinal)
decide whether "for key in dict" is a good idea
use iterators in map/filter/reduce, min/max, and elsewhere (in/not in?)
speed tuning (make next() a slot tp_next???)
16 files changed:
Include/Python.h
Include/abstract.h
Include/object.h
Include/opcode.h
Include/pyerrors.h
Lib/dis.py
Makefile.pre.in
Objects/abstract.c
Objects/classobject.c
Objects/dictobject.c
Objects/stringobject.c
Python/bltinmodule.c
Python/ceval.c
Python/compile.c
Python/exceptions.c
Python/import.c