diff options
author | Fred Drake <fdrake@acm.org> | 2000-09-21 17:43:48 (GMT) |
---|---|---|
committer | Fred Drake <fdrake@acm.org> | 2000-09-21 17:43:48 (GMT) |
commit | 07cbc4e5bd7fdc2f5e92ac65dbabf35bde002bef (patch) | |
tree | 25be35ae6ef5a7be3a35570a9d8b2a06c467e9f5 | |
parent | 5644b7fad1f354f43b3dd4ae890edcade2c0bcbc (diff) | |
download | cpython-07cbc4e5bd7fdc2f5e92ac65dbabf35bde002bef.zip cpython-07cbc4e5bd7fdc2f5e92ac65dbabf35bde002bef.tar.gz cpython-07cbc4e5bd7fdc2f5e92ac65dbabf35bde002bef.tar.bz2 |
Paul Prescod <paul@prescod.net>:
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.
-rw-r--r-- | Lib/xml/sax/xmlreader.py | 44 |
1 files changed, 27 insertions, 17 deletions
diff --git a/Lib/xml/sax/xmlreader.py b/Lib/xml/sax/xmlreader.py index 84a8bbb..3bcf2b9 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 @@ class IncrementalParser(XMLReader): 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 @@ class AttributesImpl: def values(self): return self._attrs.values() + def _test(): XMLReader() IncrementalParser() Locator() AttributesImpl() -if __name__=="__main__": +if __name__ == "__main__": _test() |