From 07cbc4e5bd7fdc2f5e92ac65dbabf35bde002bef Mon Sep 17 00:00:00 2001 From: Fred Drake Date: Thu, 21 Sep 2000 17:43:48 +0000 Subject: [PATCH] Paul Prescod : Add support for parsing already-opened files. Make sure the parse() method closes exactly those files that it opens. Modified by FLD for better conformance to the Python style guide. This closes SourceForge patch #101512. --- Lib/xml/sax/xmlreader.py | 44 ++++++++++++++++++++++++---------------- 1 file changed, 27 insertions(+), 17 deletions(-) diff --git a/Lib/xml/sax/xmlreader.py b/Lib/xml/sax/xmlreader.py index 84a8bbbabac..3bcf2b94b65 100644 --- a/Lib/xml/sax/xmlreader.py +++ b/Lib/xml/sax/xmlreader.py @@ -1,15 +1,16 @@ -import handler - """An XML Reader is the SAX 2 name for an XML parser. XML Parsers should be based on this code. """ + +import handler + # ===== XMLREADER ===== class XMLReader: def __init__(self): self._cont_handler = handler.ContentHandler() - #self._dtd_handler = handler.DTDHandler() - #self._ent_handler = handler.EntityResolver() - self._err_handler = handler.ErrorHandler() + #self._dtd_handler = handler.DTDHandler() + #self._ent_handler = handler.EntityResolver() + self._err_handler = handler.ErrorHandler() def parse(self, source): "Parse an XML document from a system identifier or an InputSource." @@ -92,22 +93,29 @@ class IncrementalParser(XMLReader): interface using the feed, close and reset methods of the IncrementalParser interface as a convenience to SAX 2.0 driver writers.""" - def __init__(self, bufsize=2**16 ): - self._bufsize=bufsize - XMLReader.__init__( self ) - - def parse(self, source): - self.prepareParser(source) - #FIXME: do some type checking: could be already stream, URL or - # filename - inf=open( source ) - buffer = inf.read(self._bufsize) + + def __init__(self, bufsize=2**16): + self._bufsize = bufsize + XMLReader.__init__(self) + + def _parseOpenFile(self, source): + buffer = source.read(self._bufsize) while buffer != "": self.feed(buffer) - buffer = inf.read(self._bufsize) + buffer = source.read(self._bufsize) self.close() self.reset() + def parse(self, source): + if hasattr(source, "read"): + self._parseOpenFile(source) + else: + #FIXME: how to recognize if it is a URL instead of filename? + self.prepareParser(source) + file = open(source) + self._parseOpenFile(file) + file.close() + def feed(self, data): """This method gives the raw XML data in the data parameter to the parser and makes it parse the data, emitting the @@ -116,6 +124,7 @@ def feed(self, data): feed may raise SAXException.""" raise NotImplementedError("This method must be implemented!") + def prepareParser(self, source): """This method is called by the parse implementation to allow the SAX 2.0 driver to prepare itself for parsing.""" @@ -215,11 +224,12 @@ def items(self): def values(self): return self._attrs.values() + def _test(): XMLReader() IncrementalParser() Locator() AttributesImpl() -if __name__=="__main__": +if __name__ == "__main__": _test()