diff options
author | William M. Brack <wbrack@src.gnome.org> | 2006-06-26 18:25:40 +0000 |
---|---|---|
committer | William M. Brack <wbrack@src.gnome.org> | 2006-06-26 18:25:40 +0000 |
commit | 40cca61fc130f0f865f51b2fb2ba15e478e102ab (patch) | |
tree | ff31d55a80b9e6cafbb3f63896c469d0f0122362 /python/libxml.c | |
parent | 631ea8176ad5ae7662145e2ab18b3a62e8838dec (diff) | |
download | android_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).
Diffstat (limited to 'python/libxml.c')
-rw-r--r-- | python/libxml.c | 36 |
1 files changed, 36 insertions, 0 deletions
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} }; |