| Index: third_party/libxml/src/python/types.c
|
| diff --git a/third_party/libxml/src/python/types.c b/third_party/libxml/src/python/types.c
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..f2376776a5d5de7d36278cc094594b3fe7589224
|
| --- /dev/null
|
| +++ b/third_party/libxml/src/python/types.c
|
| @@ -0,0 +1,957 @@
|
| +/*
|
| + * types.c: converter functions between the internal representation
|
| + * and the Python objects
|
| + *
|
| + * See Copyright for the status of this software.
|
| + *
|
| + * daniel@veillard.com
|
| + */
|
| +#include "libxml_wrap.h"
|
| +#include <libxml/xpathInternals.h>
|
| +
|
| +#if PY_MAJOR_VERSION >= 3
|
| +#define PY_IMPORT_STRING_SIZE PyUnicode_FromStringAndSize
|
| +#define PY_IMPORT_STRING PyUnicode_FromString
|
| +#define PY_IMPORT_INT PyLong_FromLong
|
| +#else
|
| +#define PY_IMPORT_STRING_SIZE PyString_FromStringAndSize
|
| +#define PY_IMPORT_STRING PyString_FromString
|
| +#define PY_IMPORT_INT PyInt_FromLong
|
| +#endif
|
| +
|
| +#if PY_MAJOR_VERSION >= 3
|
| +#include <stdio.h>
|
| +#include <unistd.h>
|
| +#include <fcntl.h>
|
| +
|
| +FILE *
|
| +libxml_PyFileGet(PyObject *f) {
|
| + int fd, flags;
|
| + FILE *res;
|
| + const char *mode;
|
| +
|
| + fd = PyObject_AsFileDescriptor(f);
|
| + if (!_PyVerify_fd(fd))
|
| + return(NULL);
|
| + /*
|
| + * Get the flags on the fd to understand how it was opened
|
| + */
|
| + flags = fcntl(fd, F_GETFL, 0);
|
| + switch (flags & O_ACCMODE) {
|
| + case O_RDWR:
|
| + if (flags & O_APPEND)
|
| + mode = "a+";
|
| + else
|
| + mode = "rw";
|
| + break;
|
| + case O_RDONLY:
|
| + if (flags & O_APPEND)
|
| + mode = "r+";
|
| + else
|
| + mode = "r";
|
| + break;
|
| + case O_WRONLY:
|
| + if (flags & O_APPEND)
|
| + mode = "a";
|
| + else
|
| + mode = "w";
|
| + break;
|
| + default:
|
| + return(NULL);
|
| + }
|
| +
|
| + /*
|
| + * the FILE struct gets a new fd, so that it can be closed
|
| + * independently of the file descriptor given. The risk though is
|
| + * lack of sync. So at the python level sync must be implemented
|
| + * before and after a conversion took place. No way around it
|
| + * in the Python3 infrastructure !
|
| + * The duplicated fd and FILE * will be released in the subsequent
|
| + * call to libxml_PyFileRelease() which must be genrated accodingly
|
| + */
|
| + fd = dup(fd);
|
| + if (fd == -1)
|
| + return(NULL);
|
| + res = fdopen(fd, mode);
|
| + if (res == NULL) {
|
| + close(fd);
|
| + return(NULL);
|
| + }
|
| + return(res);
|
| +}
|
| +
|
| +void libxml_PyFileRelease(FILE *f) {
|
| + if (f != NULL)
|
| + fclose(f);
|
| +}
|
| +#endif
|
| +
|
| +PyObject *
|
| +libxml_intWrap(int val)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_intWrap: val = %d\n", val);
|
| +#endif
|
| + ret = PY_IMPORT_INT((long) val);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_longWrap(long val)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_longWrap: val = %ld\n", val);
|
| +#endif
|
| + ret = PyLong_FromLong(val);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_doubleWrap(double val)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_doubleWrap: val = %f\n", val);
|
| +#endif
|
| + ret = PyFloat_FromDouble((double) val);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_charPtrWrap(char *str)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlcharPtrWrap: str = %s\n", str);
|
| +#endif
|
| + if (str == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret = PY_IMPORT_STRING(str);
|
| + xmlFree(str);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_charPtrConstWrap(const char *str)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlcharPtrWrap: str = %s\n", str);
|
| +#endif
|
| + if (str == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret = PY_IMPORT_STRING(str);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlCharPtrWrap(xmlChar * str)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlCharPtrWrap: str = %s\n", str);
|
| +#endif
|
| + if (str == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret = PY_IMPORT_STRING((char *) str);
|
| + xmlFree(str);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlCharPtrConstWrap(const xmlChar * str)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlCharPtrWrap: str = %s\n", str);
|
| +#endif
|
| + if (str == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret = PY_IMPORT_STRING((char *) str);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_constcharPtrWrap(const char *str)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlcharPtrWrap: str = %s\n", str);
|
| +#endif
|
| + if (str == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret = PY_IMPORT_STRING(str);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_constxmlCharPtrWrap(const xmlChar * str)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlCharPtrWrap: str = %s\n", str);
|
| +#endif
|
| + if (str == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret = PY_IMPORT_STRING((char *) str);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlDocPtrWrap(xmlDocPtr doc)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlDocPtrWrap: doc = %p\n", doc);
|
| +#endif
|
| + if (doc == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + /* TODO: look at deallocation */
|
| + ret = PyCapsule_New((void *) doc, (char *) "xmlDocPtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlNodePtrWrap(xmlNodePtr node)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlNodePtrWrap: node = %p\n", node);
|
| +#endif
|
| + if (node == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret = PyCapsule_New((void *) node, (char *) "xmlNodePtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlURIPtrWrap(xmlURIPtr uri)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlURIPtrWrap: uri = %p\n", uri);
|
| +#endif
|
| + if (uri == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret = PyCapsule_New((void *) uri, (char *) "xmlURIPtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlNsPtrWrap(xmlNsPtr ns)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlNsPtrWrap: node = %p\n", ns);
|
| +#endif
|
| + if (ns == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret = PyCapsule_New((void *) ns, (char *) "xmlNsPtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlAttrPtrWrap(xmlAttrPtr attr)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlAttrNodePtrWrap: attr = %p\n", attr);
|
| +#endif
|
| + if (attr == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret = PyCapsule_New((void *) attr, (char *) "xmlAttrPtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlAttributePtrWrap(xmlAttributePtr attr)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlAttributePtrWrap: attr = %p\n", attr);
|
| +#endif
|
| + if (attr == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret = PyCapsule_New((void *) attr, (char *) "xmlAttributePtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlElementPtrWrap(xmlElementPtr elem)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlElementNodePtrWrap: elem = %p\n", elem);
|
| +#endif
|
| + if (elem == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret = PyCapsule_New((void *) elem, (char *) "xmlElementPtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlXPathContextPtrWrap(xmlXPathContextPtr ctxt)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlXPathContextPtrWrap: ctxt = %p\n", ctxt);
|
| +#endif
|
| + if (ctxt == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret = PyCapsule_New((void *) ctxt, (char *) "xmlXPathContextPtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlXPathParserContextPtrWrap(xmlXPathParserContextPtr ctxt)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlXPathParserContextPtrWrap: ctxt = %p\n", ctxt);
|
| +#endif
|
| + if (ctxt == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret = PyCapsule_New((void *)ctxt, (char *)"xmlXPathParserContextPtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlParserCtxtPtrWrap(xmlParserCtxtPtr ctxt)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlParserCtxtPtrWrap: ctxt = %p\n", ctxt);
|
| +#endif
|
| + if (ctxt == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| +
|
| + ret = PyCapsule_New((void *) ctxt, (char *) "xmlParserCtxtPtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +/**
|
| + * libxml_xmlXPathDestructNsNode:
|
| + * cap: xmlNsPtr namespace node capsule object
|
| + *
|
| + * This function is called if and when a namespace node returned in
|
| + * an XPath node set is to be destroyed. That's the only kind of
|
| + * object returned in node set not directly linked to the original
|
| + * xmlDoc document, see xmlXPathNodeSetDupNs.
|
| + */
|
| +#if PY_VERSION_HEX < 0x02070000
|
| +static void
|
| +libxml_xmlXPathDestructNsNode(void *cap, void *desc ATTRIBUTE_UNUSED)
|
| +#else
|
| +static void
|
| +libxml_xmlXPathDestructNsNode(PyObject *cap)
|
| +#endif
|
| +{
|
| +#ifdef DEBUG
|
| + fprintf(stderr, "libxml_xmlXPathDestructNsNode called %p\n", cap);
|
| +#endif
|
| +#if PY_VERSION_HEX < 0x02070000
|
| + xmlXPathNodeSetFreeNs((xmlNsPtr) cap);
|
| +#else
|
| + xmlXPathNodeSetFreeNs((xmlNsPtr) PyCapsule_GetPointer(cap, "xmlNsPtr"));
|
| +#endif
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlXPathObjectPtrWrap(xmlXPathObjectPtr obj)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlXPathObjectPtrWrap: ctxt = %p\n", obj);
|
| +#endif
|
| + if (obj == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + switch (obj->type) {
|
| + case XPATH_XSLT_TREE: {
|
| + if ((obj->nodesetval == NULL) ||
|
| + (obj->nodesetval->nodeNr == 0) ||
|
| + (obj->nodesetval->nodeTab == NULL)) {
|
| + ret = PyList_New(0);
|
| + } else {
|
| + int i, len = 0;
|
| + xmlNodePtr node;
|
| +
|
| + node = obj->nodesetval->nodeTab[0]->children;
|
| + while (node != NULL) {
|
| + len++;
|
| + node = node->next;
|
| + }
|
| + ret = PyList_New(len);
|
| + node = obj->nodesetval->nodeTab[0]->children;
|
| + for (i = 0;i < len;i++) {
|
| + PyList_SetItem(ret, i, libxml_xmlNodePtrWrap(node));
|
| + node = node->next;
|
| + }
|
| + }
|
| + /*
|
| + * Return now, do not free the object passed down
|
| + */
|
| + return (ret);
|
| + }
|
| + case XPATH_NODESET:
|
| + if ((obj->nodesetval == NULL)
|
| + || (obj->nodesetval->nodeNr == 0)) {
|
| + ret = PyList_New(0);
|
| + } else {
|
| + int i;
|
| + xmlNodePtr node;
|
| +
|
| + ret = PyList_New(obj->nodesetval->nodeNr);
|
| + for (i = 0; i < obj->nodesetval->nodeNr; i++) {
|
| + node = obj->nodesetval->nodeTab[i];
|
| + if (node->type == XML_NAMESPACE_DECL) {
|
| + PyObject *ns = PyCapsule_New((void *) node,
|
| + (char *) "xmlNsPtr",
|
| + libxml_xmlXPathDestructNsNode);
|
| + PyList_SetItem(ret, i, ns);
|
| + /* make sure the xmlNsPtr is not destroyed now */
|
| + obj->nodesetval->nodeTab[i] = NULL;
|
| + } else {
|
| + PyList_SetItem(ret, i, libxml_xmlNodePtrWrap(node));
|
| + }
|
| + }
|
| + }
|
| + break;
|
| + case XPATH_BOOLEAN:
|
| + ret = PY_IMPORT_INT((long) obj->boolval);
|
| + break;
|
| + case XPATH_NUMBER:
|
| + ret = PyFloat_FromDouble(obj->floatval);
|
| + break;
|
| + case XPATH_STRING:
|
| + ret = PY_IMPORT_STRING((char *) obj->stringval);
|
| + break;
|
| + case XPATH_POINT:
|
| + {
|
| + PyObject *node;
|
| + PyObject *indexIntoNode;
|
| + PyObject *tuple;
|
| +
|
| + node = libxml_xmlNodePtrWrap(obj->user);
|
| + indexIntoNode = PY_IMPORT_INT((long) obj->index);
|
| +
|
| + tuple = PyTuple_New(2);
|
| + PyTuple_SetItem(tuple, 0, node);
|
| + PyTuple_SetItem(tuple, 1, indexIntoNode);
|
| +
|
| + ret = tuple;
|
| + break;
|
| + }
|
| + case XPATH_RANGE:
|
| + {
|
| + unsigned short bCollapsedRange;
|
| +
|
| + bCollapsedRange = ( (obj->user2 == NULL) ||
|
| + ((obj->user2 == obj->user) && (obj->index == obj->index2)) );
|
| + if ( bCollapsedRange ) {
|
| + PyObject *node;
|
| + PyObject *indexIntoNode;
|
| + PyObject *tuple;
|
| + PyObject *list;
|
| +
|
| + list = PyList_New(1);
|
| +
|
| + node = libxml_xmlNodePtrWrap(obj->user);
|
| + indexIntoNode = PY_IMPORT_INT((long) obj->index);
|
| +
|
| + tuple = PyTuple_New(2);
|
| + PyTuple_SetItem(tuple, 0, node);
|
| + PyTuple_SetItem(tuple, 1, indexIntoNode);
|
| +
|
| + PyList_SetItem(list, 0, tuple);
|
| +
|
| + ret = list;
|
| + } else {
|
| + PyObject *node;
|
| + PyObject *indexIntoNode;
|
| + PyObject *tuple;
|
| + PyObject *list;
|
| +
|
| + list = PyList_New(2);
|
| +
|
| + node = libxml_xmlNodePtrWrap(obj->user);
|
| + indexIntoNode = PY_IMPORT_INT((long) obj->index);
|
| +
|
| + tuple = PyTuple_New(2);
|
| + PyTuple_SetItem(tuple, 0, node);
|
| + PyTuple_SetItem(tuple, 1, indexIntoNode);
|
| +
|
| + PyList_SetItem(list, 0, tuple);
|
| +
|
| + node = libxml_xmlNodePtrWrap(obj->user2);
|
| + indexIntoNode = PY_IMPORT_INT((long) obj->index2);
|
| +
|
| + tuple = PyTuple_New(2);
|
| + PyTuple_SetItem(tuple, 0, node);
|
| + PyTuple_SetItem(tuple, 1, indexIntoNode);
|
| +
|
| + PyList_SetItem(list, 1, tuple);
|
| +
|
| + ret = list;
|
| + }
|
| + break;
|
| + }
|
| + case XPATH_LOCATIONSET:
|
| + {
|
| + xmlLocationSetPtr set;
|
| +
|
| + set = obj->user;
|
| + if ( set && set->locNr > 0 ) {
|
| + int i;
|
| + PyObject *list;
|
| +
|
| + list = PyList_New(set->locNr);
|
| +
|
| + for (i=0; i<set->locNr; i++) {
|
| + xmlXPathObjectPtr setobj;
|
| + PyObject *pyobj;
|
| +
|
| + setobj = set->locTab[i]; /*xmlXPathObjectPtr setobj*/
|
| +
|
| + pyobj = libxml_xmlXPathObjectPtrWrap(setobj);
|
| + /* xmlXPathFreeObject(setobj) is called */
|
| + set->locTab[i] = NULL;
|
| +
|
| + PyList_SetItem(list, i, pyobj);
|
| + }
|
| + set->locNr = 0;
|
| + ret = list;
|
| + } else {
|
| + Py_INCREF(Py_None);
|
| + ret = Py_None;
|
| + }
|
| + break;
|
| + }
|
| + default:
|
| +#ifdef DEBUG
|
| + printf("Unable to convert XPath object type %d\n", obj->type);
|
| +#endif
|
| + Py_INCREF(Py_None);
|
| + ret = Py_None;
|
| + }
|
| + xmlXPathFreeObject(obj);
|
| + return (ret);
|
| +}
|
| +
|
| +xmlXPathObjectPtr
|
| +libxml_xmlXPathObjectPtrConvert(PyObject *obj)
|
| +{
|
| + xmlXPathObjectPtr ret = NULL;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlXPathObjectPtrConvert: obj = %p\n", obj);
|
| +#endif
|
| + if (obj == NULL) {
|
| + return (NULL);
|
| + }
|
| + if PyFloat_Check (obj) {
|
| + ret = xmlXPathNewFloat((double) PyFloat_AS_DOUBLE(obj));
|
| + } else if PyLong_Check(obj) {
|
| +#ifdef PyLong_AS_LONG
|
| + ret = xmlXPathNewFloat((double) PyLong_AS_LONG(obj));
|
| +#else
|
| + ret = xmlXPathNewFloat((double) PyInt_AS_LONG(obj));
|
| +#endif
|
| +#ifdef PyBool_Check
|
| + } else if PyBool_Check (obj) {
|
| +
|
| + if (obj == Py_True) {
|
| + ret = xmlXPathNewBoolean(1);
|
| + }
|
| + else {
|
| + ret = xmlXPathNewBoolean(0);
|
| + }
|
| +#endif
|
| + } else if PyBytes_Check (obj) {
|
| + xmlChar *str;
|
| +
|
| + str = xmlStrndup((const xmlChar *) PyBytes_AS_STRING(obj),
|
| + PyBytes_GET_SIZE(obj));
|
| + ret = xmlXPathWrapString(str);
|
| +#ifdef PyUnicode_Check
|
| + } else if PyUnicode_Check (obj) {
|
| +#if PY_VERSION_HEX >= 0x03030000
|
| + xmlChar *str;
|
| + const char *tmp;
|
| + Py_ssize_t size;
|
| +
|
| + /* tmp doesn't need to be deallocated */
|
| + tmp = PyUnicode_AsUTF8AndSize(obj, &size);
|
| + str = xmlStrndup((const xmlChar *) tmp, (int) size);
|
| + ret = xmlXPathWrapString(str);
|
| +#else
|
| + xmlChar *str = NULL;
|
| + PyObject *b;
|
| +
|
| + b = PyUnicode_AsUTF8String(obj);
|
| + if (b != NULL) {
|
| + str = xmlStrndup((const xmlChar *) PyBytes_AS_STRING(b),
|
| + PyBytes_GET_SIZE(b));
|
| + Py_DECREF(b);
|
| + }
|
| + ret = xmlXPathWrapString(str);
|
| +#endif
|
| +#endif
|
| + } else if PyList_Check (obj) {
|
| + int i;
|
| + PyObject *node;
|
| + xmlNodePtr cur;
|
| + xmlNodeSetPtr set;
|
| +
|
| + set = xmlXPathNodeSetCreate(NULL);
|
| +
|
| + for (i = 0; i < PyList_Size(obj); i++) {
|
| + node = PyList_GetItem(obj, i);
|
| + if ((node == NULL) || (node->ob_type == NULL))
|
| + continue;
|
| +
|
| + cur = NULL;
|
| + if (PyCapsule_CheckExact(node)) {
|
| +#ifdef DEBUG
|
| + printf("Got a Capsule\n");
|
| +#endif
|
| + cur = PyxmlNode_Get(node);
|
| + } else if ((PyObject_HasAttrString(node, (char *) "_o")) &&
|
| + (PyObject_HasAttrString(node, (char *) "get_doc"))) {
|
| + PyObject *wrapper;
|
| +
|
| + wrapper = PyObject_GetAttrString(node, (char *) "_o");
|
| + if (wrapper != NULL)
|
| + cur = PyxmlNode_Get(wrapper);
|
| + } else {
|
| +#ifdef DEBUG
|
| + printf("Unknown object in Python return list\n");
|
| +#endif
|
| + }
|
| + if (cur != NULL) {
|
| + xmlXPathNodeSetAdd(set, cur);
|
| + }
|
| + }
|
| + ret = xmlXPathWrapNodeSet(set);
|
| + } else {
|
| +#ifdef DEBUG
|
| + printf("Unable to convert Python Object to XPath");
|
| +#endif
|
| + }
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlValidCtxtPtrWrap(xmlValidCtxtPtr valid)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlValidCtxtPtrWrap: valid = %p\n", valid);
|
| +#endif
|
| + if (valid == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| +
|
| + ret =
|
| + PyCapsule_New((void *) valid,
|
| + (char *) "xmlValidCtxtPtr", NULL);
|
| +
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlCatalogPtrWrap(xmlCatalogPtr catal)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlNodePtrWrap: catal = %p\n", catal);
|
| +#endif
|
| + if (catal == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret =
|
| + PyCapsule_New((void *) catal,
|
| + (char *) "xmlCatalogPtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlOutputBufferPtrWrap(xmlOutputBufferPtr buffer)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlOutputBufferPtrWrap: buffer = %p\n", buffer);
|
| +#endif
|
| + if (buffer == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret =
|
| + PyCapsule_New((void *) buffer,
|
| + (char *) "xmlOutputBufferPtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlParserInputBufferPtrWrap(xmlParserInputBufferPtr buffer)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlParserInputBufferPtrWrap: buffer = %p\n", buffer);
|
| +#endif
|
| + if (buffer == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret =
|
| + PyCapsule_New((void *) buffer,
|
| + (char *) "xmlParserInputBufferPtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +#ifdef LIBXML_REGEXP_ENABLED
|
| +PyObject *
|
| +libxml_xmlRegexpPtrWrap(xmlRegexpPtr regexp)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlRegexpPtrWrap: regexp = %p\n", regexp);
|
| +#endif
|
| + if (regexp == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret =
|
| + PyCapsule_New((void *) regexp,
|
| + (char *) "xmlRegexpPtr", NULL);
|
| + return (ret);
|
| +}
|
| +#endif /* LIBXML_REGEXP_ENABLED */
|
| +
|
| +#ifdef LIBXML_READER_ENABLED
|
| +PyObject *
|
| +libxml_xmlTextReaderPtrWrap(xmlTextReaderPtr reader)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlTextReaderPtrWrap: reader = %p\n", reader);
|
| +#endif
|
| + if (reader == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret =
|
| + PyCapsule_New((void *) reader,
|
| + (char *) "xmlTextReaderPtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlTextReaderLocatorPtrWrap(xmlTextReaderLocatorPtr locator)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlTextReaderLocatorPtrWrap: locator = %p\n", locator);
|
| +#endif
|
| + if (locator == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret =
|
| + PyCapsule_New((void *) locator,
|
| + (char *) "xmlTextReaderLocatorPtr", NULL);
|
| + return (ret);
|
| +}
|
| +#endif /* LIBXML_READER_ENABLED */
|
| +
|
| +#ifdef LIBXML_SCHEMAS_ENABLED
|
| +PyObject *
|
| +libxml_xmlRelaxNGPtrWrap(xmlRelaxNGPtr ctxt)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlRelaxNGPtrWrap: ctxt = %p\n", ctxt);
|
| +#endif
|
| + if (ctxt == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret =
|
| + PyCapsule_New((void *) ctxt,
|
| + (char *) "xmlRelaxNGPtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlRelaxNGParserCtxtPtrWrap(xmlRelaxNGParserCtxtPtr ctxt)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlRelaxNGParserCtxtPtrWrap: ctxt = %p\n", ctxt);
|
| +#endif
|
| + if (ctxt == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret =
|
| + PyCapsule_New((void *) ctxt,
|
| + (char *) "xmlRelaxNGParserCtxtPtr", NULL);
|
| + return (ret);
|
| +}
|
| +PyObject *
|
| +libxml_xmlRelaxNGValidCtxtPtrWrap(xmlRelaxNGValidCtxtPtr valid)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlRelaxNGValidCtxtPtrWrap: valid = %p\n", valid);
|
| +#endif
|
| + if (valid == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret =
|
| + PyCapsule_New((void *) valid,
|
| + (char *) "xmlRelaxNGValidCtxtPtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlSchemaPtrWrap(xmlSchemaPtr ctxt)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlSchemaPtrWrap: ctxt = %p\n", ctxt);
|
| +#endif
|
| + if (ctxt == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret =
|
| + PyCapsule_New((void *) ctxt,
|
| + (char *) "xmlSchemaPtr", NULL);
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlSchemaParserCtxtPtrWrap(xmlSchemaParserCtxtPtr ctxt)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlSchemaParserCtxtPtrWrap: ctxt = %p\n", ctxt);
|
| +#endif
|
| + if (ctxt == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret =
|
| + PyCapsule_New((void *) ctxt,
|
| + (char *) "xmlSchemaParserCtxtPtr", NULL);
|
| +
|
| + return (ret);
|
| +}
|
| +
|
| +PyObject *
|
| +libxml_xmlSchemaValidCtxtPtrWrap(xmlSchemaValidCtxtPtr valid)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlSchemaValidCtxtPtrWrap: valid = %p\n", valid);
|
| +#endif
|
| + if (valid == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| +
|
| + ret =
|
| + PyCapsule_New((void *) valid,
|
| + (char *) "xmlSchemaValidCtxtPtr", NULL);
|
| +
|
| + return (ret);
|
| +}
|
| +#endif /* LIBXML_SCHEMAS_ENABLED */
|
| +
|
| +PyObject *
|
| +libxml_xmlErrorPtrWrap(xmlErrorPtr error)
|
| +{
|
| + PyObject *ret;
|
| +
|
| +#ifdef DEBUG
|
| + printf("libxml_xmlErrorPtrWrap: error = %p\n", error);
|
| +#endif
|
| + if (error == NULL) {
|
| + Py_INCREF(Py_None);
|
| + return (Py_None);
|
| + }
|
| + ret = PyCapsule_New((void *) error, (char *) "xmlErrorPtr", NULL);
|
| + return (ret);
|
| +}
|
|
|