Commit aaa9780f authored by Eli Bendersky's avatar Eli Bendersky

Issue #9708: Fix support for iterparse(parser=...) argument per documentation.

When _elementtree is imported, iterparse is redefined as a class and the parser
argument was ommitted. Fix this, and add a docstring to the class.
parent 33f7cdd9
...@@ -1881,6 +1881,12 @@ class ElementIterTest(unittest.TestCase): ...@@ -1881,6 +1881,12 @@ class ElementIterTest(unittest.TestCase):
sourcefile = serialize(doc, to_string=False) sourcefile = serialize(doc, to_string=False)
self.assertEqual(next(ET.iterparse(sourcefile))[0], 'end') self.assertEqual(next(ET.iterparse(sourcefile))[0], 'end')
# With an explitit parser too (issue #9708)
sourcefile = serialize(doc, to_string=False)
parser = ET.XMLParser(target=ET.TreeBuilder())
self.assertEqual(next(ET.iterparse(sourcefile, parser=parser))[0],
'end')
tree = ET.ElementTree(None) tree = ET.ElementTree(None)
self.assertRaises(AttributeError, tree.iter) self.assertRaises(AttributeError, tree.iter)
......
...@@ -1737,8 +1737,20 @@ else: ...@@ -1737,8 +1737,20 @@ else:
source.close() source.close()
class iterparse: class iterparse:
"""Parses an XML section into an element tree incrementally.
Reports what’s going on to the user. 'source' is a filename or file
object containing XML data. 'events' is a list of events to report back.
The supported events are the strings "start", "end", "start-ns" and
"end-ns" (the "ns" events are used to get detailed namespace
information). If 'events' is omitted, only "end" events are reported.
'parser' is an optional parser instance. If not given, the standard
XMLParser parser is used. Returns an iterator providing
(event, elem) pairs.
"""
root = None root = None
def __init__(self, file, events=None): def __init__(self, file, events=None, parser=None):
self._close_file = False self._close_file = False
if not hasattr(file, 'read'): if not hasattr(file, 'read'):
file = open(file, 'rb') file = open(file, 'rb')
...@@ -1748,8 +1760,9 @@ else: ...@@ -1748,8 +1760,9 @@ else:
self._index = 0 self._index = 0
self._error = None self._error = None
self.root = self._root = None self.root = self._root = None
b = TreeBuilder() if parser is None:
self._parser = XMLParser(b) parser = XMLParser(target=TreeBuilder())
self._parser = parser
self._parser._setevents(self._events, events) self._parser._setevents(self._events, events)
def __next__(self): def __next__(self):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment