Used original SAX handling form.

This commit is contained in:
Paul Prescod 2000-07-04 03:39:33 +00:00
parent 99b84bdaad
commit 6c4753f925
3 changed files with 14 additions and 15 deletions

View File

@ -41,7 +41,7 @@ class Node:
Node.allnodes[index]=repr( self.__dict__ )
if Node.debug==None:
Node.debug=StringIO()
#open( "debug4.out", "w" )
#open( "debug4.out", "w" )
Node.debug.write( "create %s\n"%index )
def __getattr__( self, key ):
@ -230,7 +230,7 @@ dictionary"""
else:
assert isinstance( value, Attr ) or type( value )==types.StringType
node=value
old=self._attrs.get( attname, None)
old=self._attrs.get( attname, None)
if old:
old.unlink()
self._attrs[node.name]=node

View File

@ -22,7 +22,7 @@ class PullDOM:
def setDocumentLocator( self, locator ): pass
def startElement( self, tagName , attrs ):
def startElement( self, name, tagName , attrs ):
if not hasattr( self, "curNode" ):
# FIXME: hack!
self.startDocument( )
@ -42,7 +42,7 @@ class PullDOM:
self.lastEvent=self.lastEvent[1]
#self.events.append( (START_ELEMENT, node) )
def endElement( self, name ):
def endElement( self, name, tagName ):
node = self.curNode
self.lastEvent[1]=[(END_ELEMENT, node), None ]
self.lastEvent=self.lastEvent[1]

View File

@ -101,8 +101,8 @@ class ExpatParser( xmlreader.IncrementalParser, xmlreader.Locator ):
self._parser.EndElementHandler = self.end_element_ns
else:
self._parser = pyexpat.ParserCreate()
self._parser.StartElementHandler = self._cont_handler.startElement
self._parser.EndElementHandler = self._cont_handler.endElement
self._parser.StartElementHandler = self.start_element
self._parser.EndElementHandler = self.end_element
self._parser.ProcessingInstructionHandler = \
self._cont_handler.processingInstruction
@ -133,25 +133,22 @@ class ExpatParser( xmlreader.IncrementalParser, xmlreader.Locator ):
def getSystemId(self):
return self._parser.GetBase()
# internal methods
# event handlers
def start_element(self, name, attrs):
self._cont_handler.startElement(name,
self._cont_handler.startElement(name, name,
xmlreader.AttributesImpl(attrs, attrs))
def end_element(self, name):
self._cont_handler.endElement(name)
self._cont_handler.endElement( name, name )
def start_element_ns(self, name, attrs):
pair = split(name)
if len(pair) == 1:
tup = (None, name, None)
tup = (None, name )
else:
tup = pair+[None] # prefix is not implemented yet!
tup = pair
self._cont_handler.startElement(tup,
self._cont_handler.startElement(tup, None,
xmlreader.AttributesImpl(attrs, None))
def end_element_ns(self, name):
@ -161,11 +158,13 @@ class ExpatParser( xmlreader.IncrementalParser, xmlreader.Locator ):
else:
name = pair+[None] # prefix is not implemented yet!
self._cont_handler.endElement(name)
self._cont_handler.endElement(name, None)
# this is not used
def processing_instruction(self, target, data):
self._cont_handler.processingInstruction(target, data)
# this is not used
def character_data(self, data):
self._cont_handler.characters(data)