diff options
author | Barry Warsaw <barry@python.org> | 2004-05-09 03:42:37 (GMT) |
---|---|---|
committer | Barry Warsaw <barry@python.org> | 2004-05-09 03:42:37 (GMT) |
commit | 4c3e33a80bab417e0b8c2dd8e944f6d37709b88a (patch) | |
tree | 4592318cdaa44583fb2316792165f672ea04b9c1 /Lib/email | |
parent | 3d1f397f1a997bd2e9eb87455073e121d11c2aed (diff) | |
download | cpython-4c3e33a80bab417e0b8c2dd8e944f6d37709b88a.zip cpython-4c3e33a80bab417e0b8c2dd8e944f6d37709b88a.tar.gz cpython-4c3e33a80bab417e0b8c2dd8e944f6d37709b88a.tar.bz2 |
Update to Python 2.3, getting rid of backward compatiblity crud. We don't
need the _compat21 or _compat22 modules either.
Diffstat (limited to 'Lib/email')
-rw-r--r-- | Lib/email/Iterators.py | 62 |
1 files changed, 52 insertions, 10 deletions
diff --git a/Lib/email/Iterators.py b/Lib/email/Iterators.py index 3ecd632..2572c20 100644 --- a/Lib/email/Iterators.py +++ b/Lib/email/Iterators.py @@ -1,25 +1,67 @@ -# Copyright (C) 2001,2002 Python Software Foundation -# Author: barry@zope.com (Barry Warsaw) +# Copyright (C) 2001-2004 Python Software Foundation +# Author: Barry Warsaw <barry@python.org> """Various types of useful iterators and generators. """ import sys +from cStringIO import StringIO -try: - from email._compat22 import body_line_iterator, typed_subpart_iterator -except SyntaxError: - # Python 2.1 doesn't have generators - from email._compat21 import body_line_iterator, typed_subpart_iterator + + +# This function will become a method of the Message class +def walk(self): + """Walk over the message tree, yielding each subpart. + + The walk is performed in depth-first order. This method is a + generator. + """ + yield self + if self.is_multipart(): + for subpart in self.get_payload(): + for subsubpart in subpart.walk(): + yield subsubpart + + + +# These two functions are imported into the Iterators.py interface module. +# The Python 2.2 version uses generators for efficiency. +def body_line_iterator(msg, decode=False): + """Iterate over the parts, returning string payloads line-by-line. + + Optional decode (default False) is passed through to .get_payload(). + """ + for subpart in msg.walk(): + payload = subpart.get_payload(decode=decode) + if isinstance(payload, basestring): + for line in StringIO(payload): + yield line + + +def typed_subpart_iterator(msg, maintype='text', subtype=None): + """Iterate over the subparts with a given MIME type. + + Use `maintype' as the main MIME type to match against; this defaults to + "text". Optional `subtype' is the MIME subtype to match against; if + omitted, only the main type is matched. + """ + for subpart in msg.walk(): + if subpart.get_content_maintype() == maintype: + if subtype is None or subpart.get_content_subtype() == subtype: + yield subpart -def _structure(msg, fp=None, level=0): +def _structure(msg, fp=None, level=0, include_default=False): """A handy debugging aid""" if fp is None: fp = sys.stdout tab = ' ' * (level * 4) - print >> fp, tab + msg.get_content_type() + print >> fp, tab + msg.get_content_type(), + if include_default: + print '[%s]' % msg.get_default_type() + else: + print if msg.is_multipart(): for subpart in msg.get_payload(): - _structure(subpart, fp, level+1) + _structure(subpart, fp, level+1, include_default) |