mirror of https://github.com/python/cpython.git
Used original SAX handling form.
This commit is contained in:
parent
99b84bdaad
commit
6c4753f925
|
@ -41,7 +41,7 @@ def __init__( self ):
|
|||
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 @@ def __setitem__( self, attname, value ):
|
|||
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 @@ def __init__( self ):
|
|||
|
||||
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 @@ def startElement( self, tagName , attrs ):
|
|||
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 @@ def reset(self):
|
|||
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 @@ def getPublicId(self):
|
|||
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 @@ def end_element_ns(self, name):
|
|||
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)
|
||||
|
||||
|
|
Loading…
Reference in New Issue