summaryrefslogtreecommitdiff
path: root/ext/domxml/php_domxml.c
diff options
context:
space:
mode:
authorChristian Stocker <chregu@php.net>2003-04-03 10:21:19 +0000
committerChristian Stocker <chregu@php.net>2003-04-03 10:21:19 +0000
commit630a00dda628f0cbbc8560cc1a69ee1038664099 (patch)
tree74688895a89870c0435114ca973a309913e6c3c6 /ext/domxml/php_domxml.c
parent05e02eb27bebace6075407c148eb6f10cb0ea78f (diff)
downloadphp-git-630a00dda628f0cbbc8560cc1a69ee1038664099.tar.gz
- Added domxml_elem_set_attribute_node() method. (Rob Richards)
Diffstat (limited to 'ext/domxml/php_domxml.c')
-rw-r--r--ext/domxml/php_domxml.c68
1 files changed, 53 insertions, 15 deletions
diff --git a/ext/domxml/php_domxml.c b/ext/domxml/php_domxml.c
index 5d9057f6dd..d08e3a4cd4 100644
--- a/ext/domxml/php_domxml.c
+++ b/ext/domxml/php_domxml.c
@@ -429,9 +429,7 @@ static zend_function_entry php_domxmlelement_class_functions[] = {
PHP_FALIAS(set_attribute, domxml_elem_set_attribute, NULL)
PHP_FALIAS(remove_attribute, domxml_elem_remove_attribute, NULL)
PHP_FALIAS(get_attribute_node, domxml_elem_get_attribute_node, NULL)
-/* since this function is not implemented, outcomment it for the time beeing
PHP_FALIAS(set_attribute_node, domxml_elem_set_attribute_node, NULL)
-*/
#if defined(LIBXML_XPATH_ENABLED)
PHP_FALIAS(get_elements_by_tagname, domxml_elem_get_elements_by_tagname, NULL)
#endif
@@ -2849,32 +2847,72 @@ PHP_FUNCTION(domxml_elem_get_attribute_node)
/* {{{ proto bool domxml_elem_set_attribute_node(object attr)
Sets value of given attribute */
-/* since this function is not implemented, outcomment it for the time beeing
PHP_FUNCTION(domxml_elem_set_attribute_node)
{
- zval *id, **arg1, *rv = NULL;
+ zval *id, *node, *rv = NULL;
xmlNode *nodep;
- xmlAttr *attrp, *newattrp;
+ xmlAttr *attrp, *newattrp, *existattrp;
int ret;
- if ((ZEND_NUM_ARGS() == 1) && (zend_get_parameters_ex(1, &arg1) == FAILURE) {
- WRONG_PARAM_COUNT;
+ DOMXML_GET_THIS_OBJ(nodep, id, le_domxmlnodep);
+
+ if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "o", &node) == FAILURE) {
+ return;
}
- id = getThis();
- nodep = php_dom_get_object(id, le_domxmlelementp, 0 TSRMLS_CC);
- attrp = php_dom_get_object(*arg1, le_domxmlattrp, 0 TSRMLS_CC);
+ DOMXML_GET_OBJ(attrp, node, le_domxmlnodep);
- FIXME: The following line doesn't work
- newattrp = xmlCopyProp(nodep, attrp);
- if (!newattrp) {
- php_error_docref(NULL TSRMLS_CC, E_WARNING, "No such attribute '%s'", attrp->name);
+ if (attrp->type != XML_ATTRIBUTE_NODE) {
+ php_error_docref(NULL TSRMLS_CC, E_WARNING, "Attribute node is required");
RETURN_FALSE;
}
+
+ existattrp = xmlHasProp(nodep,attrp->name);
+ if (existattrp != NULL) {
+ /* We cannot unlink an existing attribute as it may never be freed
+ Only the content of the text node of an attribute node is transfered over */
+
+ xmlChar *mem;
+ xmlNode *first, *firstattrp;
+
+ first = existattrp->children;
+ firstattrp = attrp->children;
+ if (mem = xmlNodeGetContent(firstattrp)) {
+ if (!first) {
+ xmlNodeSetContent((xmlNode *) existattrp, mem);
+ } else {
+ xmlNodeSetContent(first, mem);
+ }
+ xmlFree(mem);
+ newattrp = existattrp;
+ } else {
+ RETURN_FALSE;
+ }
+ } else {
+ /* xmlCopyProp does not add the copy to the element node.
+ It does set the parent of the copy to the element node however */
+ newattrp = xmlCopyProp(nodep, attrp);
+ if (!newattrp) {
+ php_error_docref(NULL TSRMLS_CC, E_WARNING, "No such attribute '%s'", attrp->name);
+ RETURN_FALSE;
+ } else {
+ xmlAttr *prop;
+ prop = nodep->properties;
+ if (prop == NULL) {
+ nodep->properties = newattrp;
+ } else {
+ while (prop->next != NULL) {
+ prop = prop->next;
+ }
+ prop->next = newattrp;
+ newattrp->prev = prop;
+ }
+ }
+ }
+
DOMXML_RET_OBJ(rv, (xmlNodePtr) newattrp, &ret);
}
-*/
/* }}} */
/* {{{ proto string domxml_elem_has_attribute(string attrname)