aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWilliam M. Brack <wbrack@src.gnome.org>2006-06-26 18:25:40 +0000
committerWilliam M. Brack <wbrack@src.gnome.org>2006-06-26 18:25:40 +0000
commit40cca61fc130f0f865f51b2fb2ba15e478e102ab (patch)
treeff31d55a80b9e6cafbb3f63896c469d0f0122362
parent631ea8176ad5ae7662145e2ab18b3a62e8838dec (diff)
downloadandroid_external_libxml2-40cca61fc130f0f865f51b2fb2ba15e478e102ab.tar.gz
android_external_libxml2-40cca61fc130f0f865f51b2fb2ba15e478e102ab.tar.bz2
android_external_libxml2-40cca61fc130f0f865f51b2fb2ba15e478e102ab.zip
Added code submitted by Andreas Pakulat to provide node equality,
* python/libxml.c, python/libxml.py, python/tests/compareNodes.py, python/tests/Makefile.am: Added code submitted by Andreas Pakulat to provide node equality, inequality and hash functions, plus a single test program to check the functions (bugs 345779 + 345961).
-rw-r--r--ChangeLog8
-rw-r--r--python/libxml.c36
-rw-r--r--python/libxml.py17
-rw-r--r--python/tests/Makefile.am3
-rwxr-xr-xpython/tests/compareNodes.py50
5 files changed, 113 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index b1e30a4a..0bb08fe3 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+Mon Jun 26 17:24:28 UTC 2006 William Brack <wbrack@mmm.com.hk>
+
+ * python/libxml.c, python/libxml.py, python/tests/compareNodes.py,
+ python/tests/Makefile.am:
+ Added code submitted by Andreas Pakulat to provide node
+ equality, inequality and hash functions, plus a single
+ test program to check the functions (bugs 345779 + 345961).
+
Mon Jun 26 18:38:51 CEST 2006 Kasimier Buchcik <libxml2-cvs@cazic.net>
* xpath.c: Added xmlXPathCompiledEvalToBoolean() to the API and
diff --git a/python/libxml.c b/python/libxml.c
index 88b29cf0..6e9a78ee 100644
--- a/python/libxml.c
+++ b/python/libxml.c
@@ -3677,6 +3677,40 @@ libxml_getObjDesc(PyObject *self ATTRIBUTE_UNUSED, PyObject *args) {
return Py_BuildValue((char *)"s", str);
}
+static PyObject *
+libxml_compareNodesEqual(PyObject *self ATTRIBUTE_UNUSED, PyObject *args) {
+
+ PyObject *py_node1, *py_node2;
+ xmlNodePtr node1, node2;
+
+ if (!PyArg_ParseTuple(args, (char *)"OO:compareNodesEqual",
+ &py_node1, &py_node2))
+ return NULL;
+ /* To compare two node objects, we compare their pointer addresses */
+ node1 = PyxmlNode_Get(py_node1);
+ node2 = PyxmlNode_Get(py_node2);
+ if ( node1 == node2 )
+ return Py_BuildValue((char *)"i", 1);
+ else
+ return Py_BuildValue((char *)"i", 0);
+
+}
+
+static PyObject *
+libxml_nodeHash(PyObject *self ATTRIBUTE_UNUSED, PyObject *args) {
+
+ PyObject *py_node1;
+ xmlNodePtr node1;
+
+ if (!PyArg_ParseTuple(args, (char *)"O:nodeHash", &py_node1))
+ return NULL;
+ /* For simplicity, we use the node pointer address as a hash value */
+ node1 = PyxmlNode_Get(py_node1);
+
+ return PyLong_FromVoidPtr(node1);
+
+}
+
/************************************************************************
* *
* The registration stuff *
@@ -3730,6 +3764,8 @@ static PyMethodDef libxmlMethods[] = {
#endif
#endif
{(char *) "getObjDesc", libxml_getObjDesc, METH_VARARGS, NULL},
+ {(char *) "compareNodesEqual", libxml_compareNodesEqual, METH_VARARGS, NULL},
+ {(char *) "nodeHash", libxml_nodeHash, METH_VARARGS, NULL},
{NULL, NULL, 0, NULL}
};
diff --git a/python/libxml.py b/python/libxml.py
index 997e15f4..f7c31299 100644
--- a/python/libxml.py
+++ b/python/libxml.py
@@ -232,6 +232,23 @@ class xmlCore:
self._o = _obj;
return
self._o = None
+
+ def __eq__(self, other):
+ if other == None:
+ return False
+ ret = libxml2mod.compareNodesEqual(self._o, other._o)
+ if ret == None:
+ return False
+ return ret == True
+ def __ne__(self, other):
+ if other == None:
+ return True
+ ret = libxml2mod.compareNodesEqual(self._o, other._o)
+ return not ret
+ def __hash__(self):
+ ret = libxml2mod.nodeHash(self._o)
+ return ret
+
def __str__(self):
return self.serialize()
def get_parent(self):
diff --git a/python/tests/Makefile.am b/python/tests/Makefile.am
index 3571abfa..39950f63 100644
--- a/python/tests/Makefile.am
+++ b/python/tests/Makefile.am
@@ -43,7 +43,8 @@ PYTESTS= \
tstmem.py \
validDTD.py \
validSchemas.py \
- validRNG.py
+ validRNG.py \
+ compareNodes.py
XMLS= \
tst.xml \
diff --git a/python/tests/compareNodes.py b/python/tests/compareNodes.py
new file mode 100755
index 00000000..ec043232
--- /dev/null
+++ b/python/tests/compareNodes.py
@@ -0,0 +1,50 @@
+#!/usr/bin/python -u
+import sys
+import libxml2
+
+# Memory debug specific
+libxml2.debugMemory(1)
+
+#
+# Testing XML Node comparison and Node hash-value
+#
+doc = libxml2.parseDoc("""<root><foo/></root>""")
+root = doc.getRootElement()
+
+# Create two different objects which point to foo
+foonode1 = root.children
+foonode2 = root.children
+
+# Now check that [in]equality tests work ok
+if not ( foonode1 == foonode2 ):
+ print "Error comparing nodes with ==, nodes should be equal but are unequal"
+ sys.exit(1)
+if not ( foonode1 != root ):
+ print "Error comparing nodes with ==, nodes should not be equal but are equal"
+ sys.exit(1)
+if not ( foonode1 != root ):
+ print "Error comparing nodes with !=, nodes should not be equal but are equal"
+if ( foonode1 != foonode2 ):
+ print "Error comparing nodes with !=, nodes should be equal but are unequal"
+
+# Next check that the hash function for the objects also works ok
+if not (hash(foonode1) == hash(foonode2)):
+ print "Error hash values for two equal nodes are different"
+ sys.exit(1)
+if not (hash(foonode1) != hash(root)):
+ print "Error hash values for two unequal nodes are not different"
+ sys.exit(1)
+if hash(foonode1) == hash(root):
+ print "Error hash values for two unequal nodes are equal"
+ sys.exit(1)
+
+# Basic tests successful
+doc.freeDoc()
+
+# Memory debug specific
+libxml2.cleanupParser()
+if libxml2.debugMemory(1) == 0:
+ print "OK"
+else:
+ print "Memory leak %d bytes" % (libxml2.debugMemory(1))
+ libxml2.dumpMemory()