diff options
author | Lars Gustäbel <lars@gustaebel.de> | 2000-09-24 18:54:49 (GMT) |
---|---|---|
committer | Lars Gustäbel <lars@gustaebel.de> | 2000-09-24 18:54:49 (GMT) |
commit | 523b0a6ec87ac7f84de8a004e3c33581eb2a542f (patch) | |
tree | d12ad6fecb01461ee48a7d55876e56f32d0305fe /Lib/xml/sax/expatreader.py | |
parent | b7536d58606ec06e81453ca8fd1b14292f7427a9 (diff) | |
download | cpython-523b0a6ec87ac7f84de8a004e3c33581eb2a542f.zip cpython-523b0a6ec87ac7f84de8a004e3c33581eb2a542f.tar.gz cpython-523b0a6ec87ac7f84de8a004e3c33581eb2a542f.tar.bz2 |
Added back the InputSource class (patch 101630).
Diffstat (limited to 'Lib/xml/sax/expatreader.py')
-rw-r--r-- | Lib/xml/sax/expatreader.py | 22 |
1 files changed, 9 insertions, 13 deletions
diff --git a/Lib/xml/sax/expatreader.py b/Lib/xml/sax/expatreader.py index 2f1ff1c..341efd3 100644 --- a/Lib/xml/sax/expatreader.py +++ b/Lib/xml/sax/expatreader.py @@ -18,7 +18,7 @@ version = "0.20" from xml.sax._exceptions import * from xml.parsers import expat -from xml.sax import xmlreader +from xml.sax import xmlreader, saxutils AttributesImpl = xmlreader.AttributesImpl AttributesNSImpl = xmlreader.AttributesNSImpl @@ -37,28 +37,24 @@ class ExpatParser(xmlreader.IncrementalParser, xmlreader.Locator): # XMLReader methods - def parse(self, stream_or_string): + def parse(self, source): "Parse an XML document from a URL." - if type(stream_or_string) is type(""): - stream = open(stream_or_string) - else: - stream = stream_or_string - + source = saxutils.prepare_input_source(source) + + self._source = source self.reset() self._cont_handler.setDocumentLocator(self) try: - xmlreader.IncrementalParser.parse(self, stream) + xmlreader.IncrementalParser.parse(self, source) except expat.error: error_code = self._parser.ErrorCode raise SAXParseException(expat.ErrorString(error_code), None, self) self._cont_handler.endDocument() - def prepareParser(self, filename=None): - self._source = filename - - if self._source != None: - self._parser.SetBase(self._source) + def prepareParser(self, source): + if source.getSystemId() != None: + self._parser.SetBase(source.getSystemId()) def getFeature(self, name): if name == feature_namespaces: |