From f573fd1077d913f6a4d0a7858b2e9efbf3ea0ce2 Mon Sep 17 00:00:00 2001 From: Rob Richards Date: Mon, 14 May 2007 11:44:50 +0000 Subject: [PATCH] Fixed bug #41374 (wholetext concats values of wrong nodes). add test --- ext/dom/tests/bug41374.phpt | 32 ++++++++++++++++++++++++++++++++ ext/dom/text.c | 20 +++++++++++++++++--- 2 files changed, 49 insertions(+), 3 deletions(-) create mode 100644 ext/dom/tests/bug41374.phpt diff --git a/ext/dom/tests/bug41374.phpt b/ext/dom/tests/bug41374.phpt new file mode 100644 index 0000000000..6de5ffbc05 --- /dev/null +++ b/ext/dom/tests/bug41374.phpt @@ -0,0 +1,32 @@ +--TEST-- +Bug # 41374: (wholetext concats values of wrong nodes) +--SKIPIF-- + +--FILE-- + +foobaz +EOXML; + +$doc = new DOMDocument(); +$doc->loadXML($xml); + +$root = $doc->documentElement; +$foo = $root->firstChild; + +var_dump($foo->wholeText == "foo"); + +$bar = $root->insertBefore($doc->createTextNode("bar"), $foo->nextSibling); + +var_dump($foo->wholeText == "foobar"); +var_dump($foo->wholeText == $bar->wholeText); +$baz = $bar->nextSibling->nextSibling; + +var_dump($baz->wholeText === $foo->wholeText); +?> +--EXPECT-- +bool(true) +bool(true) +bool(true) +bool(false) diff --git a/ext/dom/text.c b/ext/dom/text.c index 73fdd612c4..f420271a92 100644 --- a/ext/dom/text.c +++ b/ext/dom/text.c @@ -87,7 +87,7 @@ Since: DOM Level 3 int dom_text_whole_text_read(dom_object *obj, zval **retval TSRMLS_DC) { xmlNodePtr node; - xmlChar *wholetext; + xmlChar *wholetext = NULL; node = dom_object_get_node(obj); @@ -96,9 +96,23 @@ int dom_text_whole_text_read(dom_object *obj, zval **retval TSRMLS_DC) return FAILURE; } + /* Find starting text node */ + while (node->prev && ((node->prev->type == XML_TEXT_NODE) || (node->prev->type == XML_CDATA_SECTION_NODE))) { + node = node->prev; + } + + /* concatenate all adjacent text and cdata nodes */ + while (node && ((node->type == XML_TEXT_NODE) || (node->type == XML_CDATA_SECTION_NODE))) { + wholetext = xmlStrcat(wholetext, node->content); + node = node->next; + } + ALLOC_ZVAL(*retval); - wholetext = xmlNodeListGetString(node->doc, node, 1); - ZVAL_XML_STRING(*retval, wholetext, ZSTR_DUPLICATE); + if (wholetext != NULL) { + ZVAL_XML_STRING(*retval, wholetext, ZSTR_DUPLICATE); + } else { + ZVAL_EMPTY_STRING(*retval); + } xmlFree(wholetext); -- 2.50.1