summaryrefslogtreecommitdiff
path: root/ext/dom
diff options
context:
space:
mode:
authorRob Richards <rrichards@php.net>2003-10-26 15:57:02 +0000
committerRob Richards <rrichards@php.net>2003-10-26 15:57:02 +0000
commit207dc90924f69b662efedd83a95970fda4685cb0 (patch)
treefbc237f51941ffa0835ce068f3a02a653a27372d /ext/dom
parentd29fb55bbb6c33aa10861f312176c07dafe61046 (diff)
downloadphp-git-207dc90924f69b662efedd83a95970fda4685cb0.tar.gz
add interop with simplexml - dom_import_simplexml
fix cloneNode with elements
Diffstat (limited to 'ext/dom')
-rw-r--r--ext/dom/attr.c4
-rw-r--r--ext/dom/cdatasection.c4
-rw-r--r--ext/dom/comment.c4
-rw-r--r--ext/dom/document.c27
-rw-r--r--ext/dom/documentfragment.c5
-rw-r--r--ext/dom/domimplementation.c4
-rw-r--r--ext/dom/element.c12
-rw-r--r--ext/dom/entityreference.c4
-rw-r--r--ext/dom/node.c59
-rw-r--r--ext/dom/php_dom.c311
-rw-r--r--ext/dom/php_dom.h12
-rw-r--r--ext/dom/processinginstruction.c4
-rw-r--r--ext/dom/text.c4
-rw-r--r--ext/dom/xml_common.h28
-rw-r--r--ext/dom/xpath.c4
15 files changed, 139 insertions, 347 deletions
diff --git a/ext/dom/attr.c b/ext/dom/attr.c
index 3dc615a08e..c9f6475a51 100644
--- a/ext/dom/attr.c
+++ b/ext/dom/attr.c
@@ -74,9 +74,9 @@ PHP_FUNCTION(dom_attr_attr)
if (intern != NULL) {
oldnode = (xmlNodePtr)intern->ptr;
if (oldnode != NULL) {
- node_free_resource(oldnode TSRMLS_CC);
+ php_libxml_node_free_resource(oldnode TSRMLS_CC);
}
- php_dom_set_object(intern, (xmlNodePtr) nodep TSRMLS_CC);
+ php_libxml_increment_node_ptr((php_libxml_node_object *)intern, (xmlNodePtr)nodep, (void *)intern TSRMLS_CC);
}
}
diff --git a/ext/dom/cdatasection.c b/ext/dom/cdatasection.c
index 00a65481db..49b222fbc5 100644
--- a/ext/dom/cdatasection.c
+++ b/ext/dom/cdatasection.c
@@ -66,9 +66,9 @@ PHP_FUNCTION(dom_cdatasection_cdatasection)
if (intern != NULL) {
oldnode = (xmlNodePtr)intern->ptr;
if (oldnode != NULL) {
- node_free_resource(oldnode TSRMLS_CC);
+ php_libxml_node_free_resource(oldnode TSRMLS_CC);
}
- php_dom_set_object(intern, nodep TSRMLS_CC);
+ php_libxml_increment_node_ptr((php_libxml_node_object *)intern, nodep, (void *)intern TSRMLS_CC);
}
}
/* }}} end dom_cdatasection_cdatasection */
diff --git a/ext/dom/comment.c b/ext/dom/comment.c
index c982e0692e..da10b0806b 100644
--- a/ext/dom/comment.c
+++ b/ext/dom/comment.c
@@ -65,9 +65,9 @@ PHP_FUNCTION(dom_comment_comment)
if (intern != NULL) {
oldnode = (xmlNodePtr)intern->ptr;
if (oldnode != NULL) {
- node_free_resource(oldnode TSRMLS_CC);
+ php_libxml_node_free_resource(oldnode TSRMLS_CC);
}
- php_dom_set_object(intern, nodep TSRMLS_CC);
+ php_libxml_increment_node_ptr((php_libxml_node_object *)intern, (xmlNodePtr)nodep, (void *)intern TSRMLS_CC);
}
}
/* }}} end dom_comment_comment */
diff --git a/ext/dom/document.c b/ext/dom/document.c
index 4982a6b7e8..d8df916477 100644
--- a/ext/dom/document.c
+++ b/ext/dom/document.c
@@ -1164,16 +1164,15 @@ PHP_FUNCTION(dom_document_document)
if (intern != NULL) {
olddoc = (xmlDocPtr) dom_object_get_node(intern);
if (olddoc != NULL) {
- decrement_node_ptr(intern TSRMLS_CC);
- refcount = decrement_document_reference(intern TSRMLS_CC);
+ php_libxml_decrement_node_ptr((php_libxml_node_object *) intern TSRMLS_CC);
+ refcount = php_libxml_decrement_doc_ref((php_libxml_node_object *)intern TSRMLS_CC);
if (refcount != 0) {
olddoc->_private = NULL;
}
}
intern->document = NULL;
- increment_document_reference(intern, docp TSRMLS_CC);
-
- php_dom_set_object(intern, (xmlNodePtr) docp TSRMLS_CC);
+ php_libxml_increment_doc_ref((php_libxml_node_object *)intern, docp TSRMLS_CC);
+ php_libxml_increment_node_ptr((php_libxml_node_object *)intern, (xmlNodePtr)docp, (void *)intern TSRMLS_CC);
}
}
/* }}} end dom_document_document */
@@ -1230,7 +1229,7 @@ static xmlDocPtr dom_document_parser(zval *id, int mode, char *source TSRMLS_DC)
xmlParserCtxtPtr ctxt = NULL;
dom_doc_props *doc_props;
dom_object *intern;
- dom_ref_obj *document = NULL;
+ php_libxml_ref_obj *document = NULL;
int validate, resolve_externals, keep_blanks, substitute_ent;
int resolved_path_len;
char *directory=NULL, resolved_path[MAXPATHLEN];
@@ -1352,20 +1351,20 @@ static void dom_parse_document(INTERNAL_FUNCTION_PARAMETERS, int mode) {
docp = (xmlDocPtr) dom_object_get_node(intern);
doc_prop = NULL;
if (docp != NULL) {
- decrement_node_ptr(intern TSRMLS_CC);
+ php_libxml_decrement_node_ptr((php_libxml_node_object *) intern TSRMLS_CC);
doc_prop = intern->document->doc_props;
intern->document->doc_props = NULL;
- refcount = decrement_document_reference(intern TSRMLS_CC);
+ refcount = php_libxml_decrement_doc_ref((php_libxml_node_object *)intern TSRMLS_CC);
if (refcount != 0) {
docp->_private = NULL;
}
}
intern->document = NULL;
- increment_document_reference(intern, newdoc TSRMLS_CC);
+ php_libxml_increment_doc_ref((php_libxml_node_object *)intern, newdoc TSRMLS_CC);
intern->document->doc_props = doc_prop;
}
- php_dom_set_object(intern, (xmlNodePtr) newdoc TSRMLS_CC);
+ php_libxml_increment_node_ptr((php_libxml_node_object *)intern, (xmlNodePtr)newdoc, (void *)intern TSRMLS_CC);
RETURN_TRUE;
} else {
@@ -1710,20 +1709,20 @@ static void dom_load_html(INTERNAL_FUNCTION_PARAMETERS, int mode)
docp = (xmlDocPtr) dom_object_get_node(intern);
doc_prop = NULL;
if (docp != NULL) {
- decrement_node_ptr(intern TSRMLS_CC);
+ php_libxml_decrement_node_ptr((php_libxml_node_object *) intern TSRMLS_CC);
doc_prop = intern->document->doc_props;
intern->document->doc_props = NULL;
- refcount = decrement_document_reference(intern TSRMLS_CC);
+ refcount = php_libxml_decrement_doc_ref((php_libxml_node_object *)intern TSRMLS_CC);
if (refcount != 0) {
docp->_private = NULL;
}
}
intern->document = NULL;
- increment_document_reference(intern, newdoc TSRMLS_CC);
+ php_libxml_increment_doc_ref((php_libxml_node_object *)intern, newdoc TSRMLS_CC);
intern->document->doc_props = doc_prop;
}
- php_dom_set_object(intern, (xmlNodePtr) newdoc TSRMLS_CC);
+ php_libxml_increment_node_ptr((php_libxml_node_object *)intern, (xmlNodePtr)newdoc, (void *)intern TSRMLS_CC);
RETURN_TRUE;
} else {
diff --git a/ext/dom/documentfragment.c b/ext/dom/documentfragment.c
index 97d0618503..76235c5fd5 100644
--- a/ext/dom/documentfragment.c
+++ b/ext/dom/documentfragment.c
@@ -59,9 +59,10 @@ PHP_FUNCTION(dom_documentfragment_documentfragment)
if (intern != NULL) {
oldnode = (xmlNodePtr)intern->ptr;
if (oldnode != NULL) {
- node_free_resource(oldnode TSRMLS_CC);
+ php_libxml_node_free_resource(oldnode TSRMLS_CC);
}
- php_dom_set_object(intern, nodep TSRMLS_CC);
+ //php_dom_set_object(intern, nodep TSRMLS_CC);
+ php_libxml_increment_node_ptr((php_libxml_node_object *)intern, nodep, (void *)intern TSRMLS_CC);
}
}
/* }}} end dom_documentfragment_documentfragment */
diff --git a/ext/dom/domimplementation.c b/ext/dom/domimplementation.c
index 6b476e5094..3020d1dd3d 100644
--- a/ext/dom/domimplementation.c
+++ b/ext/dom/domimplementation.c
@@ -217,8 +217,8 @@ PHP_FUNCTION(dom_domimplementation_create_document)
DOM_RET_OBJ(rv, (xmlNodePtr) docp, &ret, NULL);
if (doctobj != NULL) {
- doctobj->document = ((dom_object *)((node_ptr *)docp->_private)->_private)->document;
- increment_document_reference(doctobj, docp TSRMLS_CC);
+ doctobj->document = ((dom_object *)((php_libxml_node_ptr *)docp->_private)->_private)->document;
+ php_libxml_increment_doc_ref((php_libxml_node_object *)doctobj, docp TSRMLS_CC);
}
}
/* }}} end dom_domimplementation_create_document */
diff --git a/ext/dom/element.c b/ext/dom/element.c
index 8e36486807..1d59ee2a8c 100644
--- a/ext/dom/element.c
+++ b/ext/dom/element.c
@@ -92,9 +92,9 @@ PHP_FUNCTION(dom_element_element)
if (intern != NULL) {
oldnode = (xmlNodePtr)intern->ptr;
if (oldnode != NULL) {
- node_free_resource(oldnode TSRMLS_CC);
+ php_libxml_node_free_resource(oldnode TSRMLS_CC);
}
- php_dom_set_object(intern, nodep TSRMLS_CC);
+ php_libxml_increment_node_ptr((php_libxml_node_object *)intern, nodep, (void *)intern TSRMLS_CC);
}
}
/* }}} end dom_element_element */
@@ -322,7 +322,7 @@ PHP_FUNCTION(dom_element_set_attribute_node)
existattrp = xmlHasProp(nodep, attrp->name);
if (existattrp != NULL) {
if ((oldobj = dom_object_get_data((xmlNodePtr) existattrp)) != NULL &&
- ((node_ptr *)oldobj->ptr)->node == (xmlNodePtr) attrp)
+ ((php_libxml_node_ptr *)oldobj->ptr)->node == (xmlNodePtr) attrp)
{
RETURN_NULL();
}
@@ -331,7 +331,7 @@ PHP_FUNCTION(dom_element_set_attribute_node)
if (attrp->doc == NULL && nodep->doc != NULL) {
attrobj->document = intern->document;
- increment_document_reference(attrobj, NULL TSRMLS_CC);
+ php_libxml_increment_doc_ref((php_libxml_node_object *)attrobj, NULL TSRMLS_CC);
}
xmlAddChild(nodep, (xmlNodePtr) attrp);
@@ -673,7 +673,7 @@ PHP_FUNCTION(dom_element_set_attribute_node_ns)
if (existattrp != NULL) {
if ((oldobj = dom_object_get_data((xmlNodePtr) existattrp)) != NULL &&
- ((node_ptr *)oldobj->ptr)->node == (xmlNodePtr) attrp)
+ ((php_libxml_node_ptr *)oldobj->ptr)->node == (xmlNodePtr) attrp)
{
RETURN_NULL();
}
@@ -682,7 +682,7 @@ PHP_FUNCTION(dom_element_set_attribute_node_ns)
if (attrp->doc == NULL && nodep->doc != NULL) {
attrobj->document = intern->document;
- increment_document_reference(attrobj, NULL TSRMLS_CC);
+ php_libxml_increment_doc_ref((php_libxml_node_object *)attrobj, NULL TSRMLS_CC);
}
xmlAddChild(nodep, (xmlNodePtr) attrp);
diff --git a/ext/dom/entityreference.c b/ext/dom/entityreference.c
index 780be4b0d1..5cc4eb517f 100644
--- a/ext/dom/entityreference.c
+++ b/ext/dom/entityreference.c
@@ -70,9 +70,9 @@ PHP_FUNCTION(dom_entityreference_entityreference)
if (intern != NULL) {
oldnode = (xmlNodePtr)intern->ptr;
if (oldnode != NULL) {
- node_free_resource(oldnode TSRMLS_CC);
+ php_libxml_node_free_resource(oldnode TSRMLS_CC);
}
- php_dom_set_object(intern, node TSRMLS_CC);
+ php_libxml_increment_node_ptr((php_libxml_node_object *)intern, node, (void *)intern TSRMLS_CC);
}
}
diff --git a/ext/dom/node.c b/ext/dom/node.c
index 483c88dc57..fc146051d5 100644
--- a/ext/dom/node.c
+++ b/ext/dom/node.c
@@ -780,7 +780,7 @@ PHP_FUNCTION(dom_node_insert_before)
if (child->doc == NULL && parentp->doc != NULL) {
childobj->document = intern->document;
- increment_document_reference(childobj, NULL TSRMLS_CC);
+ php_libxml_increment_doc_ref((php_libxml_node_object *)childobj, NULL TSRMLS_CC);
}
if (ref != NULL) {
@@ -802,14 +802,14 @@ PHP_FUNCTION(dom_node_insert_before)
tmp = xmlStrcat(tmp, refp->content);
xmlNodeSetContent(refp, tmp);
xmlFree(tmp);
- node_free_resource(child TSRMLS_CC);
+ php_libxml_node_free_resource(child TSRMLS_CC);
DOM_RET_OBJ(rv, refp, &ret, intern);
return;
}
if ((refp->prev != NULL) && (refp->prev->type == XML_TEXT_NODE)
&& (refp->name == refp->prev->name)) {
xmlNodeAddContent(refp->prev, child->content);
- node_free_resource(child TSRMLS_CC);
+ php_libxml_node_free_resource(child TSRMLS_CC);
DOM_RET_OBJ(rv, refp->prev, &ret, intern);
return;
}
@@ -823,9 +823,7 @@ PHP_FUNCTION(dom_node_insert_before)
if (lastattr != NULL) {
if (lastattr != (xmlAttrPtr) child) {
xmlUnlinkNode((xmlNodePtr) lastattr);
- node_free_resource((xmlNodePtr) lastattr TSRMLS_CC);
- /* Freed above
- xmlFreeProp(lastattr); */
+ php_libxml_node_free_resource((xmlNodePtr) lastattr TSRMLS_CC);
} else {
DOM_RET_OBJ(rv, child, &ret, intern);
return;
@@ -843,7 +841,7 @@ PHP_FUNCTION(dom_node_insert_before)
(parentp->content != NULL) &&
(parentp != child)) {
xmlNodeAddContent(parentp, child->content);
- node_free_resource(child TSRMLS_CC);
+ php_libxml_node_free_resource(child TSRMLS_CC);
DOM_RET_OBJ(rv, parentp, &ret, intern);
return;
}
@@ -851,7 +849,7 @@ PHP_FUNCTION(dom_node_insert_before)
(parentp->last->name == child->name) &&
(parentp->last != child)) {
xmlNodeAddContent(parentp->last, child->content);
- node_free_resource(child TSRMLS_CC);
+ php_libxml_node_free_resource(child TSRMLS_CC);
DOM_RET_OBJ(rv, parentp->last, &ret, intern);
return;
}
@@ -865,9 +863,7 @@ PHP_FUNCTION(dom_node_insert_before)
if (lastattr != NULL) {
if (lastattr != (xmlAttrPtr) child) {
xmlUnlinkNode((xmlNodePtr) lastattr);
- node_free_resource((xmlNodePtr) lastattr TSRMLS_CC);
- /* Freed above
- xmlFreeProp(lastattr); */
+ php_libxml_node_free_resource((xmlNodePtr) lastattr TSRMLS_CC);
} else {
DOM_RET_OBJ(rv, child, &ret, intern);
return;
@@ -960,7 +956,7 @@ PHP_FUNCTION(dom_node_replace_child)
if (newchild->doc == NULL && nodep->doc != NULL) {
xmlSetTreeDoc(newchild, nodep->doc);
newchildobj->document = intern->document;
- increment_document_reference(newchildobj, NULL TSRMLS_CC);
+ php_libxml_increment_doc_ref((php_libxml_node_object *)newchildobj, NULL TSRMLS_CC);
}
node = xmlReplaceNode(oldchild, newchild);
}
@@ -1072,7 +1068,7 @@ PHP_FUNCTION(dom_node_append_child)
if (child->doc == NULL && nodep->doc != NULL) {
childobj->document = intern->document;
- increment_document_reference(childobj, NULL TSRMLS_CC);
+ php_libxml_increment_doc_ref((php_libxml_node_object *)childobj, NULL TSRMLS_CC);
}
if (child->parent != NULL){
@@ -1083,14 +1079,14 @@ PHP_FUNCTION(dom_node_append_child)
if ((nodep->type == XML_TEXT_NODE) &&
(nodep->content != NULL)) {
xmlNodeAddContent(nodep, child->content);
- node_free_resource(child TSRMLS_CC);
+ php_libxml_node_free_resource(child TSRMLS_CC);
DOM_RET_OBJ(rv, nodep, &ret, intern);
return;
}
if ((nodep->last != NULL) && (nodep->last->type == XML_TEXT_NODE) &&
(nodep->last->name == child->name)) {
xmlNodeAddContent(nodep->last, child->content);
- node_free_resource(child TSRMLS_CC);
+ php_libxml_node_free_resource(child TSRMLS_CC);
DOM_RET_OBJ(rv, nodep->last, &ret, intern);
return;
}
@@ -1104,9 +1100,7 @@ PHP_FUNCTION(dom_node_append_child)
if (lastattr != NULL) {
if (lastattr != (xmlAttrPtr) child) {
xmlUnlinkNode((xmlNodePtr) lastattr);
- node_free_resource((xmlNodePtr) lastattr TSRMLS_CC);
- /* Freed above
- xmlFreeProp(lastattr); */
+ php_libxml_node_free_resource((xmlNodePtr) lastattr TSRMLS_CC);
}
}
} else if (child->type == XML_DOCUMENT_FRAG_NODE) {
@@ -1186,6 +1180,35 @@ PHP_FUNCTION(dom_node_clone_node)
}
node = xmlDocCopyNode(n, n->doc, recursive);
+
+ /* When deep is false Element nodes still require the attributes
+ Following taken from libxml as xmlDocCopyNode doesnt do this */
+ if (node && n->type == XML_ELEMENT_NODE && recursive == 0) {
+ if (n->nsDef != NULL) {
+ node->nsDef = xmlCopyNamespaceList(n->nsDef);
+ }
+ if (n->ns != NULL) {
+ xmlNsPtr ns;
+ ns = xmlSearchNs(n->doc, node, n->ns->prefix);
+ if (ns == NULL) {
+ ns = xmlSearchNs(n->doc, n, n->ns->prefix);
+ if (ns != NULL) {
+ xmlNodePtr root = node;
+
+ while (root->parent != NULL) {
+ root = root->parent;
+ }
+ node->ns = xmlNewNs(root, ns->href, ns->prefix);
+ }
+ } else {
+ node->ns = ns;
+ }
+ }
+ if (n->properties != NULL) {
+ node->properties = xmlCopyPropList(node, n->properties);
+ }
+ }
+
if (!node) {
RETURN_FALSE;
}
diff --git a/ext/dom/php_dom.c b/ext/dom/php_dom.c
index 159cb804c0..04409f294f 100644
--- a/ext/dom/php_dom.c
+++ b/ext/dom/php_dom.c
@@ -32,7 +32,6 @@
#include "dom_properties.h"
#include "ext/standard/info.h"
-#include "ext/libxml/php_libxml.h"
#define PHP_XPATH 1
#define PHP_XPTR 2
@@ -71,10 +70,6 @@ typedef struct _dom_prop_handler {
dom_write_t write_func;
} dom_prop_handler;
-static zend_function_entry dom_functions[] = {
- {NULL, NULL, NULL}
-};
-
/* {{{ int dom_node_is_read_only(xmlNodePtr node) */
int dom_node_is_read_only(xmlNodePtr node) {
switch (node->type) {
@@ -117,7 +112,7 @@ int dom_node_children_valid(xmlNodePtr node) {
/* }}} end dom_node_children_valid */
/* {{{ dom_get_doc_props() */
-dom_doc_propsptr dom_get_doc_props(dom_ref_obj *document)
+dom_doc_propsptr dom_get_doc_props(php_libxml_ref_obj *document)
{
dom_doc_props *doc_props;
@@ -140,7 +135,7 @@ dom_doc_propsptr dom_get_doc_props(dom_ref_obj *document)
/* }}} */
/* {{{ dom_get_strict_error() */
-int dom_get_strict_error(dom_ref_obj *document) {
+int dom_get_strict_error(php_libxml_ref_obj *document) {
int stricterror;
dom_doc_props *doc_props;
@@ -154,151 +149,28 @@ int dom_get_strict_error(dom_ref_obj *document) {
}
/* }}} */
-/* {{{ increment_document_reference() */
-int increment_document_reference(dom_object *object, xmlDocPtr docp TSRMLS_DC) {
- int ret_refcount = -1;
-
- if (object->document != NULL) {
- object->document->refcount++;
- ret_refcount = object->document->refcount;
- } else if (docp != NULL) {
- ret_refcount = 1;
- object->document = emalloc(sizeof(dom_ref_obj));
- object->document->ptr = docp;
- object->document->refcount = ret_refcount;
- object->document->doc_props = NULL;
- }
-
- return ret_refcount;
-}
-/* }}} end increment_document_reference */
-
-/* {{{ int decrement_document_reference(dom_object *object) */
-int decrement_document_reference(dom_object *object TSRMLS_DC) {
- int ret_refcount = -1;
-
- if (object != NULL && object->document != NULL) {
- object->document->refcount--;
- ret_refcount = object->document->refcount;
- if (ret_refcount == 0) {
- if (object->document->ptr != NULL) {
- xmlFreeDoc((xmlDoc *) object->document->ptr);
- object->document->ptr = NULL;
- }
- if (object->document->doc_props != NULL) {
- efree(object->document->doc_props);
- }
- efree(object->document);
- }
- object->document = NULL;
- }
-
- return ret_refcount;
-}
-/* }}} end decrement_document_reference */
-
-/* {{{ int decrement_node_ptr(dom_object *object) */
-int decrement_node_ptr(dom_object *object TSRMLS_DC) {
- int ret_refcount = -1;
- node_ptr *obj_node;
-
- if (object != NULL && object->ptr != NULL) {
- obj_node = (node_ptr *) object->ptr;
- ret_refcount = --obj_node->refcount;
- if (ret_refcount == 0) {
- if (obj_node->node != NULL) {
- obj_node->node->_private = NULL;
- }
- efree(object->ptr);
- }
- object->ptr = NULL;
- }
-
- return ret_refcount;
-}
-/* }}} end decrement_node_ptr */
-
/* {{{ xmlNodePtr dom_object_get_node(dom_object *obj) */
xmlNodePtr dom_object_get_node(dom_object *obj)
{
if (obj->ptr != NULL) {
- return ((node_ptr *)obj->ptr)->node;
+ return ((php_libxml_node_ptr *)obj->ptr)->node;
} else {
return NULL;
}
}
/* }}} end dom_object_get_node */
-/* {{{ dom_object_set_data */
-static void dom_object_set_data(xmlNodePtr obj, dom_object *wrapper TSRMLS_DC)
-{
- if (wrapper == NULL) {
- obj->_private = NULL;
- } else {
- obj->_private = wrapper->ptr;
- }
-}
-/* }}} end dom_object_set_data */
-
/* {{{ dom_object *dom_object_get_data(xmlNodePtr obj) */
dom_object *dom_object_get_data(xmlNodePtr obj)
{
if (obj->_private != NULL) {
- return (dom_object *) ((node_ptr *) obj->_private)->_private;
+ return (dom_object *) ((php_libxml_node_ptr *) obj->_private)->_private;
} else {
return NULL;
}
}
/* }}} end dom_object_get_data */
-/* {{{ php_dom_clear_object */
-static int php_dom_clear_object(dom_object *object TSRMLS_DC)
-{
- if (object->prop_handler) {
- object->prop_handler = NULL;
- }
- decrement_node_ptr(object TSRMLS_CC);
- return decrement_document_reference(object TSRMLS_CC);
-}
-/* }}} end php_dom_clear_object */
-
-/* {{{ void php_dom_set_object(dom_object *object, xmlNodePtr obj TSRMLS_DC) */
-void php_dom_set_object(dom_object *object, xmlNodePtr obj TSRMLS_DC)
-{
- node_ptr *obj_node;
-
- if (obj->_private == NULL) {
- object->ptr = emalloc(sizeof(node_ptr));
- obj_node = (node_ptr *)object->ptr;
- obj_node->node = obj;
- obj_node->refcount = 1;
- obj_node->_private = object;
- dom_object_set_data(obj, object TSRMLS_CC);
- } else if (object->ptr == NULL) {
- (node_ptr *)object->ptr = obj->_private;
- obj_node = (node_ptr *)object->ptr;
- obj_node->refcount++;
- if (obj_node->_private == NULL) {
- obj_node->_private = object;
- }
- }
-}
-/* }}} end php_dom_set_object */
-
-/* {{{ dom_unregister_node */
-static int dom_unregister_node(xmlNodePtr nodep TSRMLS_DC)
-{
- dom_object *wrapper;
-
- wrapper = dom_object_get_data(nodep);
- if (wrapper != NULL ) {
- return php_dom_clear_object(wrapper TSRMLS_CC);
- }
-
- return -1;
-}
-/* }}} end dom_unregister_node */
-
/* {{{ dom_read_na */
static int dom_read_na(dom_object *obj, zval **retval TSRMLS_DC)
{
@@ -409,6 +281,41 @@ void dom_write_property(zval *object, zval *member, zval *value TSRMLS_DC)
}
/* }}} */
+/* {{{ proto somNode dom_import_simplexml(sxeobject node)
+ Get a simplexml_element object from dom to allow for processing */
+PHP_FUNCTION(dom_import_simplexml)
+{
+#ifdef HAVE_SIMPLEXML
+ zval *rv = NULL;
+ zval *node;
+ xmlNodePtr nodep;
+ php_libxml_node_object *nodeobj;
+ int ret;
+
+ if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "o", &node) == FAILURE) {
+ return;
+ }
+
+ NODE_GET_OBJ(nodep, node, xmlNodePtr, nodeobj);
+
+ if (nodep->type == XML_ELEMENT_NODE || nodep->type == XML_ATTRIBUTE_NODE) {
+ DOM_RET_OBJ(rv, (xmlNodePtr) nodep, &ret, (dom_object *)nodeobj);
+ } else {
+ php_error(E_WARNING, "Invalid Nodetype to import");
+ RETURN_NULL();
+ }
+#else
+ php_error(E_WARNING, "SimpleXML support is not enabled");
+ return;
+#endif
+}
+/* }}} */
+
+static zend_function_entry dom_functions[] = {
+ PHP_FE(dom_import_simplexml, NULL)
+ {NULL, NULL, NULL}
+};
+
zend_module_entry dom_module_entry = {
STANDARD_MODULE_HEADER,
"dom",
@@ -815,125 +722,6 @@ void node_list_unlink(xmlNodePtr node TSRMLS_DC)
}
/* }}} end node_list_unlink */
-
-/* {{{ void dom_node_free(xmlNodePtr node) */
-void dom_node_free(xmlNodePtr node)
-{
- if(node) {
- if (node->_private != NULL) {
- ((node_ptr *) node->_private)->node = NULL;
- }
- switch (node->type) {
- case XML_ATTRIBUTE_NODE:
- xmlFreeProp((xmlAttrPtr) node);
- break;
- case XML_ENTITY_DECL:
- case XML_ELEMENT_DECL:
- case XML_ATTRIBUTE_DECL:
- break;
- case XML_NOTATION_NODE:
- /* These require special handling */
- if (node->name != NULL) {
- xmlFree((char *) node->name);
- }
- if (((xmlEntityPtr) node)->ExternalID != NULL) {
- xmlFree((char *) ((xmlEntityPtr) node)->ExternalID);
- }
- if (((xmlEntityPtr) node)->SystemID != NULL) {
- xmlFree((char *) ((xmlEntityPtr) node)->SystemID);
- }
- xmlFree(node);
- break;
- case XML_NAMESPACE_DECL:
- if (node->ns) {
- xmlFreeNs(node->ns);
- node->ns = NULL;
- }
- node->type = XML_ELEMENT_NODE;
- default:
- xmlFreeNode(node);
- }
- }
-}
-/* }}} end dom_node_free */
-
-/* {{{ node_free_list */
-void node_free_list(xmlNodePtr node TSRMLS_DC)
-{
- xmlNodePtr curnode;
-
- if (node != NULL) {
- curnode = node;
- while (curnode != NULL) {
- node = curnode;
- switch (node->type) {
- /* Skip property freeing for the following types */
- case XML_NOTATION_NODE:
- break;
- case XML_ENTITY_REF_NODE:
- node_free_list((xmlNodePtr) node->properties TSRMLS_CC);
- break;
- case XML_ATTRIBUTE_DECL:
- case XML_DTD_NODE:
- case XML_DOCUMENT_TYPE_NODE:
- case XML_ENTITY_DECL:
- case XML_ATTRIBUTE_NODE:
- case XML_NAMESPACE_DECL:
- node_free_list(node->children TSRMLS_CC);
- break;
- default:
- node_free_list(node->children TSRMLS_CC);
- node_free_list((xmlNodePtr) node->properties TSRMLS_CC);
- }
-
- curnode = node->next;
- xmlUnlinkNode(node);
- if (dom_unregister_node(node TSRMLS_CC) == 0) {
- node->doc = NULL;
- }
- dom_node_free(node);
- }
- }
-}
-/* }}} end node_free_list */
-
-/* {{{ node_free_resource */
-void node_free_resource(xmlNodePtr node TSRMLS_DC)
-{
- if (!node) {
- return;
- }
-
- switch (node->type) {
- case XML_DOCUMENT_NODE:
- case XML_HTML_DOCUMENT_NODE:
- break;
- default:
- if (node->parent == NULL || node->type == XML_NAMESPACE_DECL) {
- node_free_list((xmlNodePtr) node->children TSRMLS_CC);
- switch (node->type) {
- /* Skip property freeing for the following types */
- case XML_ATTRIBUTE_DECL:
- case XML_DTD_NODE:
- case XML_DOCUMENT_TYPE_NODE:
- case XML_ENTITY_DECL:
- case XML_ATTRIBUTE_NODE:
- case XML_NAMESPACE_DECL:
- break;
- default:
- node_free_list((xmlNodePtr) node->properties TSRMLS_CC);
- }
- if (dom_unregister_node(node TSRMLS_CC) == 0) {
- node->doc = NULL;
- }
- dom_node_free(node);
- } else {
- dom_unregister_node(node TSRMLS_CC);
- }
- }
-}
-/* }}} */
-
/* {{{ dom_objects_clone */
void dom_objects_clone(void *object, void **object_clone TSRMLS_DC)
{
@@ -952,7 +740,7 @@ void dom_xpath_objects_dtor(void *object, zend_object_handle handle TSRMLS_DC)
if (intern->ptr != NULL) {
xmlXPathFreeContext((xmlXPathContextPtr) intern->ptr);
- decrement_document_reference((dom_object *) intern TSRMLS_CC);
+ php_libxml_decrement_doc_ref((php_libxml_node_object *) intern TSRMLS_CC);
intern->ptr = NULL;
}
@@ -970,12 +758,13 @@ void dom_objects_dtor(void *object, zend_object_handle handle TSRMLS_DC)
zend_hash_destroy(intern->std.properties);
FREE_HASHTABLE(intern->std.properties);
- if (intern->ptr != NULL && ((node_ptr *)intern->ptr)->node != NULL) {
- if (((xmlNodePtr) ((node_ptr *)intern->ptr)->node)->type != XML_DOCUMENT_NODE && ((xmlNodePtr) ((node_ptr *)intern->ptr)->node)->type != XML_HTML_DOCUMENT_NODE) {
- node_free_resource(dom_object_get_node(intern) TSRMLS_CC);
+ if (intern->ptr != NULL && ((php_libxml_node_ptr *)intern->ptr)->node != NULL) {
+ if (((xmlNodePtr) ((php_libxml_node_ptr *)intern->ptr)->node)->type != XML_DOCUMENT_NODE && ((xmlNodePtr) ((php_libxml_node_ptr *)intern->ptr)->node)->type != XML_HTML_DOCUMENT_NODE) {
+ // php_libxml_node_free_resource(dom_object_get_node(intern) TSRMLS_CC);
+ php_libxml_node_decrement_resource((php_libxml_node_object *) intern TSRMLS_CC);
} else {
- decrement_node_ptr(intern TSRMLS_CC);
- retcount = decrement_document_reference(intern TSRMLS_CC);
+ php_libxml_decrement_node_ptr((php_libxml_node_object *) intern TSRMLS_CC);
+ retcount = php_libxml_decrement_doc_ref((php_libxml_node_object *)intern TSRMLS_CC);
}
intern->ptr = NULL;
}
@@ -1004,7 +793,7 @@ static dom_object* dom_objects_set_class(zend_class_entry *class_type TSRMLS_DC)
base_class = base_class->parent;
}
- zend_hash_find(&classes, base_class->name , base_class->name_length + 1, (void **) &intern->prop_handler);
+ zend_hash_find(&classes, base_class->name, base_class->name_length + 1, (void **) &intern->prop_handler);
ALLOC_HASHTABLE(intern->std.properties);
zend_hash_init(intern->std.properties, 0, NULL, ZVAL_PTR_DTOR, 0);
@@ -1157,10 +946,10 @@ zval *php_dom_create_object(xmlNodePtr obj, int *found, zval *wrapper_in, zval *
if (domobj != NULL) {
intern->document = domobj->document;
}
- increment_document_reference(intern, obj->doc TSRMLS_CC);
+ php_libxml_increment_doc_ref((php_libxml_node_object *)intern, obj->doc TSRMLS_CC);
}
- php_dom_set_object(intern, (void *) obj TSRMLS_CC);
+ php_libxml_increment_node_ptr((php_libxml_node_object *)intern, obj, (void *)intern TSRMLS_CC);
return (wrapper);
}
/* }}} end php_domobject_new */
@@ -1247,7 +1036,7 @@ void dom_normalize (xmlNodePtr nodep TSRMLS_DC)
xmlNodeAddContent(child, strContent);
xmlFree(strContent);
xmlUnlinkNode(nextp);
- node_free_resource(nextp TSRMLS_CC);
+ php_libxml_node_free_resource(nextp TSRMLS_CC);
nextp = newnextp;
} else {
break;
diff --git a/ext/dom/php_dom.h b/ext/dom/php_dom.h
index da7c75f18c..beeb85f87c 100644
--- a/ext/dom/php_dom.h
+++ b/ext/dom/php_dom.h
@@ -54,6 +54,7 @@ extern zend_module_entry dom_module_entry;
#endif
#include "xml_common.h"
+#include "ext/libxml/php_libxml.h"
#include "zend_default_classes.h"
/* DOM API_VERSION, please bump it up, if you change anything in the API
therefore it's easier for the script-programmers to check, what's working how
@@ -63,21 +64,16 @@ extern zend_module_entry dom_module_entry;
#include "dom_fe.h"
-void php_dom_set_object(dom_object *object, xmlNodePtr obj TSRMLS_DC);
dom_object *dom_object_get_data(xmlNodePtr obj);
xmlNodePtr dom_object_get_node(dom_object *obj);
-dom_doc_propsptr dom_get_doc_props(dom_ref_obj *document);
+dom_doc_propsptr dom_get_doc_props(php_libxml_ref_obj *document);
zend_object_value dom_objects_new(zend_class_entry *class_type TSRMLS_DC);
#if defined(LIBXML_XPATH_ENABLED)
zend_object_value dom_xpath_objects_new(zend_class_entry *class_type TSRMLS_DC);
#endif
-int dom_get_strict_error(dom_ref_obj *document);
+int dom_get_strict_error(php_libxml_ref_obj *document);
void php_dom_throw_error(int error_code, int strict_error TSRMLS_DC);
-void node_free_resource(xmlNodePtr node TSRMLS_DC);
void node_list_unlink(xmlNodePtr node TSRMLS_DC);
-int decrement_node_ptr(dom_object *object TSRMLS_DC);
-int increment_document_reference(dom_object *object, xmlDocPtr docp TSRMLS_DC);
-int decrement_document_reference(dom_object *object TSRMLS_DC);
int dom_check_qname(char *qname, char **localname, char **prefix, int uri_len, int name_len);
xmlNsPtr dom_get_ns(xmlNodePtr node, char *uri, int *errorcode, char *prefix);
void dom_set_old_ns(xmlDoc *doc, xmlNs *ns);
@@ -97,7 +93,7 @@ entry = zend_register_internal_class_ex(&ce, parent_ce, NULL TSRMLS_CC);
#define DOM_GET_OBJ(__ptr, __id, __prtype, __intern) { \
__intern = (dom_object *)zend_object_store_get_object(__id TSRMLS_CC); \
- if (__intern->ptr == NULL || !(__ptr = (__prtype)((node_ptr *)__intern->ptr)->node)) { \
+ if (__intern->ptr == NULL || !(__ptr = (__prtype)((php_libxml_node_ptr *)__intern->ptr)->node)) { \
php_error(E_WARNING, "Couldn't fetch %s", __intern->std.ce->name);\
RETURN_NULL();\
} \
diff --git a/ext/dom/processinginstruction.c b/ext/dom/processinginstruction.c
index b6d98cc997..0ac93d6239 100644
--- a/ext/dom/processinginstruction.c
+++ b/ext/dom/processinginstruction.c
@@ -70,9 +70,9 @@ PHP_FUNCTION(dom_processinginstruction_processinginstruction)
if (intern != NULL) {
oldnode = (xmlNodePtr)intern->ptr;
if (oldnode != NULL) {
- node_free_resource(oldnode TSRMLS_CC);
+ php_libxml_node_free_resource(oldnode TSRMLS_CC);
}
- php_dom_set_object(intern, nodep TSRMLS_CC);
+ php_libxml_increment_node_ptr((php_libxml_node_object *)intern, nodep, (void *)intern TSRMLS_CC);
}
}
/* }}} end dom_processinginstruction_processinginstruction */
diff --git a/ext/dom/text.c b/ext/dom/text.c
index 980c7c594d..2e93bdd9a2 100644
--- a/ext/dom/text.c
+++ b/ext/dom/text.c
@@ -68,9 +68,9 @@ PHP_FUNCTION(dom_text_text)
if (intern != NULL) {
oldnode = (xmlNodePtr)intern->ptr;
if (oldnode != NULL) {
- node_free_resource(oldnode TSRMLS_CC);
+ php_libxml_node_free_resource(oldnode TSRMLS_CC);
}
- php_dom_set_object(intern, nodep TSRMLS_CC);
+ php_libxml_increment_node_ptr((php_libxml_node_object *)intern, nodep, (void *)intern TSRMLS_CC);
}
}
/* }}} end dom_text_text */
diff --git a/ext/dom/xml_common.h b/ext/dom/xml_common.h
index 92205dc25e..a8990bc33a 100644
--- a/ext/dom/xml_common.h
+++ b/ext/dom/xml_common.h
@@ -22,6 +22,8 @@
#ifndef PHP_XML_COMMON_H
#define PHP_XML_COMMON_H
+#include "ext/libxml/php_libxml.h"
+
typedef struct _dom_doc_props {
int formatoutput;
int validateonparse;
@@ -33,28 +35,10 @@ typedef struct _dom_doc_props {
typedef dom_doc_props *dom_doc_propsptr;
-typedef struct _dom_ref_obj {
- void *ptr;
- int refcount;
- dom_doc_props *doc_props;
-} dom_ref_obj;
-
-typedef struct _node_ptr {
- xmlNodePtr node;
- int refcount;
- void *_private;
-} node_ptr;
-
-typedef struct _node_object {
- zend_object std;
- node_ptr *node;
- dom_ref_obj *document;
-} node_object;
-
typedef struct _dom_object {
zend_object std;
void *ptr;
- dom_ref_obj *document;
+ php_libxml_ref_obj *document;
HashTable *prop_handler;
zend_object_handle handle;
} dom_object;
@@ -80,15 +64,15 @@ PHP_DOM_EXPORT(void) dom_write_property(zval *object, zval *member, zval *value
(const xmlChar *) "http://www.w3.org/2000/xmlns/"
#define NODE_GET_OBJ(__ptr, __id, __prtype, __intern) { \
- __intern = (node_object *)zend_object_store_get_object(__id TSRMLS_CC); \
- if (__intern->ptr == NULL || !(__ptr = (__prtype)__intern->ptr->node)) { \
+ __intern = (php_libxml_node_object *)zend_object_store_get_object(__id TSRMLS_CC); \
+ if (__intern->node == NULL || !(__ptr = (__prtype)__intern->node->node)) { \
php_error(E_WARNING, "Couldn't fetch %s", __intern->std.ce->name);\
RETURN_NULL();\
} \
}
#define DOC_GET_OBJ(__ptr, __id, __prtype, __intern) { \
- __intern = (node_object *)zend_object_store_get_object(__id TSRMLS_CC); \
+ __intern = (php_libxml_node_object *)zend_object_store_get_object(__id TSRMLS_CC); \
if (__intern->document != NULL) { \
if (!(__ptr = (__prtype)__intern->document->ptr)) { \
php_error(E_WARNING, "Couldn't fetch %s", __intern->std.ce->name);\
diff --git a/ext/dom/xpath.c b/ext/dom/xpath.c
index cc9e8f3600..a0cbf46773 100644
--- a/ext/dom/xpath.c
+++ b/ext/dom/xpath.c
@@ -66,12 +66,12 @@ PHP_FUNCTION(dom_xpath_xpath)
if (intern != NULL) {
oldctx = (xmlXPathContextPtr)intern->ptr;
if (oldctx != NULL) {
- decrement_document_reference(intern TSRMLS_CC);
+ php_libxml_decrement_doc_ref((php_libxml_node_object *)intern TSRMLS_CC);
xmlXPathFreeContext(oldctx);
}
intern->ptr = ctx;
intern->document = docobj->document;
- increment_document_reference(intern, docp TSRMLS_CC);
+ php_libxml_increment_doc_ref((php_libxml_node_object *)intern, docp TSRMLS_CC);
}
}
/* }}} end dom_xpath_xpath */