Viewing file: reader7.py (1.72 KB) -rwxr-xr-x Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
#!/usr/bin/python -u # # this tests the entities substitutions with the XmlTextReader interface # import sys import StringIO import libxml2
# Memory debug specific libxml2.debugMemory(1)
result = "" def processNode(reader): global result
result = result + "%d %d %s %d\n" % (reader.Depth(), reader.NodeType(), reader.Name(), reader.IsEmptyElement())
# # Parse a document testing the readerForxxx API # docstr="""<foo> <label>some text</label> <item>100</item> </foo>""" expect="""0 1 foo 0 1 14 #text 0 1 1 label 0 2 3 #text 0 1 15 label 0 1 14 #text 0 1 1 item 0 2 3 #text 0 1 15 item 0 1 14 #text 0 0 15 foo 0 """ result = ""
reader = libxml2.readerForDoc(docstr, "test1", None, 0) ret = reader.Read() while ret == 1: processNode(reader) ret = reader.Read()
if ret != 0: print "Error parsing the document test1" sys.exit(1)
if result != expect: print "Unexpected result for test1" print result sys.exit(1)
# # Reuse the reader for another document testing the ReaderNewxxx API # docstr="""<foo> <label>some text</label> <item>1000</item> </foo>""" expect="""0 1 foo 0 1 14 #text 0 1 1 label 0 2 3 #text 0 1 15 label 0 1 14 #text 0 1 1 item 0 2 3 #text 0 1 15 item 0 1 14 #text 0 0 15 foo 0 """ result = ""
reader.NewDoc(docstr, "test2", None, 0) ret = reader.Read() while ret == 1: processNode(reader) ret = reader.Read()
if ret != 0: print "Error parsing the document test2" sys.exit(1)
if result != expect: print "Unexpected result for test2" print result sys.exit(1)
# # cleanup # del reader
# Memory debug specific libxml2.cleanupParser() if libxml2.debugMemory(1) == 0: print "OK" else: print "Memory leak %d bytes" % (libxml2.debugMemory(1)) libxml2.dumpMemory()
|