Kaydet (Commit) 6c4753f9 authored tarafından Paul Prescod's avatar Paul Prescod

Used original SAX handling form.

üst 99b84bda
......@@ -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
......
......@@ -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]
......
......@@ -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)
......
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