]> granicus.if.org Git - php/commitdiff
MFB: implement workaround for bug #38823 (DOMComment->appendData does nothing)
authorRob Richards <rrichards@php.net>
Sat, 16 Sep 2006 13:56:25 +0000 (13:56 +0000)
committerRob Richards <rrichards@php.net>
Sat, 16 Sep 2006 13:56:25 +0000 (13:56 +0000)
fix bug #38850 (lookupNamespaceURI doesn't return default namespace)
add test

ext/dom/characterdata.c
ext/dom/node.c
ext/dom/tests/bug38850.phpt [new file with mode: 0644]

index 52169939d623116097ab9f90980ab9209e4944c3..4abd1f148fa74607e7f493fcdb5f5f3a47497c8c 100644 (file)
@@ -207,9 +207,19 @@ PHP_FUNCTION(dom_characterdata_append_data)
        }
 
        DOM_GET_OBJ(nodep, id, xmlNodePtr, intern);
-
+#if LIBXML_VERSION < 20627
+/* Implement logic from libxml xmlTextConcat to add suport for comments and PI */
+    if ((nodep->content == (xmlChar *) &(nodep->properties)) ||
+        ((nodep->doc != NULL) && (nodep->doc->dict != NULL) &&
+               xmlDictOwns(nodep->doc->dict, nodep->content))) {
+       nodep->content = xmlStrncatNew(nodep->content, arg, arg_len);
+    } else {
+        nodep->content = xmlStrncat(nodep->content, arg, arg_len);
+    }
+    nodep->properties = NULL;
+#else
        xmlTextConcat(nodep, arg, arg_len);
-
+#endif
        RETURN_TRUE;
 }
 /* }}} end dom_characterdata_append_data */
index 45834387429946088c02b0bbac80fae820558c36..67ac9704982e1c8398c67d6c3a6d49023d8b6ee8 100644 (file)
@@ -1611,20 +1611,18 @@ PHP_FUNCTION(dom_node_lookup_namespace_uri)
        dom_object *intern;
        xmlNsPtr nsptr;
        int prefix_len = 0;
-       char *prefix;
+       char *prefix=NULL;
 
-       if (zend_parse_method_parameters(ZEND_NUM_ARGS() TSRMLS_CC, getThis(), "Os&", &id, dom_node_class_entry, &prefix, &prefix_len, UG(utf8_conv)) == FAILURE) {
+       if (zend_parse_method_parameters(ZEND_NUM_ARGS() TSRMLS_CC, getThis(), "Os!&", &id, dom_node_class_entry, &prefix, &prefix_len, UG(utf8_conv)) == FAILURE) {
                return;
        }
 
        DOM_GET_OBJ(nodep, id, xmlNodePtr, intern);
 
-       if (prefix_len > 0) {
-               nsptr = xmlSearchNs(nodep->doc, nodep, prefix);
-               if (nsptr && nsptr->href != NULL) {
-                       RETVAL_XML_STRING((char *) nsptr->href, ZSTR_DUPLICATE);
-                       return;
-               }
+       nsptr = xmlSearchNs(nodep->doc, nodep, prefix);
+       if (nsptr && nsptr->href != NULL) {
+               RETVAL_XML_STRING((char *) nsptr->href, ZSTR_DUPLICATE);
+               return;
        }
 
        RETURN_NULL();
diff --git a/ext/dom/tests/bug38850.phpt b/ext/dom/tests/bug38850.phpt
new file mode 100644 (file)
index 0000000..2f5d84e
--- /dev/null
@@ -0,0 +1,22 @@
+--TEST--
+Bug # 38850 (lookupNamespaceURI does not return default namespace)
+--SKIPIF--
+<?php require_once('skipif.inc'); ?>
+--FILE--
+<?php
+$xml = b<<<HERE
+<?xml version="1.0" ?>
+<foo xmlns="http://www.example.com/ns/foo" />
+HERE;
+
+$doc = new DOMDocument();
+$doc->loadXML($xml);
+
+$root = $doc->documentElement;
+
+print $root->lookupNamespaceURI(NULL);
+
+
+?>
+--EXPECT--
+http://www.example.com/ns/foo