mirror of
				https://gitlab.gnome.org/GNOME/libxml2.git
				synced 2025-10-24 13:33:01 +03:00 
			
		
		
		
	As per https://peps.python.org/pep-0394/, the python binary can be one of the following options: - Python 2 - Python 3 - Not exist All of the scripts in libxml2 use 'python', which may not exist. As Python 2 reached EOL on the 1st January 2020, it's safe to move the scripts to use python3 explicitly.
		
			
				
	
	
		
			139 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env python3
 | |
| import sys
 | |
| import libxml2
 | |
| 
 | |
| # Memory debug specific
 | |
| libxml2.debugMemory(1)
 | |
| 
 | |
| log = ""
 | |
| 
 | |
| class callback:
 | |
|     def startDocument(self):
 | |
|         global log
 | |
|         log = log + "startDocument:"
 | |
| 
 | |
|     def endDocument(self):
 | |
|         global log
 | |
|         log = log + "endDocument:"
 | |
| 
 | |
|     def startElement(self, tag, attrs):
 | |
|         global log
 | |
|         log = log + "startElement %s %s:" % (tag, attrs)
 | |
| 
 | |
|     def endElement(self, tag):
 | |
|         global log
 | |
|         log = log + "endElement %s:" % (tag)
 | |
| 
 | |
|     def characters(self, data):
 | |
|         global log
 | |
|         log = log + "characters: %s:" % (data)
 | |
| 
 | |
|     def warning(self, msg):
 | |
|         global log
 | |
|         log = log + "warning: %s:" % (msg)
 | |
| 
 | |
|     def error(self, msg):
 | |
|         global log
 | |
|         log = log + "error: %s:" % (msg)
 | |
| 
 | |
|     def fatalError(self, msg):
 | |
|         global log
 | |
|         log = log + "fatalError: %s:" % (msg)
 | |
| 
 | |
| handler = callback()
 | |
| 
 | |
| log=""
 | |
| chunk="""<foo><bar2/>"""
 | |
| ctxt = libxml2.createPushParser(handler, None, 0, "test.xml")
 | |
| ctxt.parseChunk(chunk, len(chunk), 0)
 | |
| ctxt=None
 | |
| 
 | |
| reference = "startDocument:startElement foo None:startElement bar2 None:endElement bar2:"
 | |
| if log != reference:
 | |
|     print("Error got: %s" % log)
 | |
|     print("Expected: %s" % reference)
 | |
|     sys.exit(1)
 | |
| 
 | |
| log=""
 | |
| chunk="""<foo><bar2></bar2>"""
 | |
| ctxt = libxml2.createPushParser(handler, None, 0, "test.xml")
 | |
| ctxt.parseChunk(chunk, len(chunk), 0)
 | |
| ctxt=None
 | |
| 
 | |
| reference = "startDocument:startElement foo None:startElement bar2 None:endElement bar2:"
 | |
| if log != reference:
 | |
|     print("Error got: %s" % log)
 | |
|     print("Expected: %s" % reference)
 | |
|     sys.exit(1)
 | |
| 
 | |
| log=""
 | |
| chunk="""<foo><bar2>"""
 | |
| ctxt = libxml2.createPushParser(handler, None, 0, "test.xml")
 | |
| ctxt.parseChunk(chunk, len(chunk), 0)
 | |
| ctxt=None
 | |
| 
 | |
| reference = "startDocument:startElement foo None:startElement bar2 None:"
 | |
| if log != reference:
 | |
|     print("Error got: %s" % log)
 | |
|     print("Expected: %s" % reference)
 | |
|     sys.exit(1)
 | |
| 
 | |
| log=""
 | |
| chunk="""<foo><bar2 a="1" b='2' />"""
 | |
| ctxt = libxml2.createPushParser(handler, None, 0, "test.xml")
 | |
| ctxt.parseChunk(chunk, len(chunk), 0)
 | |
| ctxt=None
 | |
| 
 | |
| reference1 = "startDocument:startElement foo None:startElement bar2 {'a': '1', 'b': '2'}:endElement bar2:"
 | |
| reference2 = "startDocument:startElement foo None:startElement bar2 {'b': '2', 'a': '1'}:endElement bar2:"
 | |
| if log not in (reference1, reference2):
 | |
|     print("Error got: %s" % log)
 | |
|     print("Expected: %s" % reference)
 | |
|     sys.exit(1)
 | |
| 
 | |
| log=""
 | |
| chunk="""<foo><bar2 a="1" b='2' >"""
 | |
| ctxt = libxml2.createPushParser(handler, None, 0, "test.xml")
 | |
| ctxt.parseChunk(chunk, len(chunk), 0)
 | |
| ctxt=None
 | |
| 
 | |
| reference1 = "startDocument:startElement foo None:startElement bar2 {'a': '1', 'b': '2'}:"
 | |
| reference2 = "startDocument:startElement foo None:startElement bar2 {'b': '2', 'a': '1'}:"
 | |
| if log not in (reference1, reference2):
 | |
|     print("Error got: %s" % log)
 | |
|     print("Expected: %s" % reference)
 | |
|     sys.exit(1)
 | |
| 
 | |
| log=""
 | |
| chunk="""<foo><bar2 a="1" b='2' ></bar2>"""
 | |
| ctxt = libxml2.createPushParser(handler, None, 0, "test.xml")
 | |
| ctxt.parseChunk(chunk, len(chunk), 0)
 | |
| ctxt=None
 | |
| 
 | |
| reference1 = "startDocument:startElement foo None:startElement bar2 {'a': '1', 'b': '2'}:endElement bar2:"
 | |
| reference2 = "startDocument:startElement foo None:startElement bar2 {'b': '2', 'a': '1'}:endElement bar2:"
 | |
| if log not in (reference1, reference2):
 | |
|     print("Error got: %s" % log)
 | |
|     print("Expected: %s" % reference)
 | |
|     sys.exit(1)
 | |
| 
 | |
| log=""
 | |
| chunk="""<foo><bar2 a="b='1' />"""
 | |
| ctxt = libxml2.createPushParser(handler, None, 0, "test.xml")
 | |
| ctxt.parseChunk(chunk, len(chunk), 0)
 | |
| ctxt=None
 | |
| 
 | |
| reference = "startDocument:startElement foo None:"
 | |
| if log != reference:
 | |
|     print("Error got: %s" % log)
 | |
|     print("Expected: %s" % reference)
 | |
|     sys.exit(1)
 | |
| 
 | |
| # Memory debug specific
 | |
| libxml2.cleanupParser()
 | |
| if libxml2.debugMemory(1) == 0:
 | |
|     print("OK")
 | |
| else:
 | |
|     print("Memory leak %d bytes" % (libxml2.debugMemory(1)))
 | |
|     libxml2.dumpMemory()
 |