]> granicus.if.org Git - php/commitdiff
MFH: fix bug #40836 (Segfault in ext/dom)
authorRob Richards <rrichards@php.net>
Sun, 18 Mar 2007 21:31:05 +0000 (21:31 +0000)
committerRob Richards <rrichards@php.net>
Sun, 18 Mar 2007 21:31:05 +0000 (21:31 +0000)
add test

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

index f9c359ba8dcf2f8a996a53e406c7259a7e31a937..d5cb04853782afb9e00678e30e4244445637b7fa 100644 (file)
@@ -1012,7 +1012,7 @@ PHP_FUNCTION(dom_node_insert_before)
                        new_child = xmlAddPrevSibling(refp, child);
                }
        } else {
-               if (child->parent == parentp){
+               if (child->parent != NULL){
                        xmlUnlinkNode(child);
                }
                if (child->type == XML_TEXT_NODE && parentp->last != NULL && parentp->last->type == XML_TEXT_NODE) {
diff --git a/ext/dom/tests/bug40836.phpt b/ext/dom/tests/bug40836.phpt
new file mode 100644 (file)
index 0000000..5f454c8
--- /dev/null
@@ -0,0 +1,29 @@
+--TEST--
+Bug # 40836 (Segfault in insertBefore)
+--SKIPIF--
+<?php require_once('skipif.inc'); ?>
+--FILE--
+<?php
+$dom = new DOMDocument("1.0", "UTF-8");
+$dom->preserveWhiteSpace = false;
+$xml = (binary)'<?xml version="1.0" encoding="utf-8"?>
+<feed xmlns="http://www.w3.org/2005/Atom">
+  <entry xmlns="http://www.w3.org/2005/Atom">
+    <updated>2007-02-14T00:00:00+01:00</updated>
+    <content>
+      <div xmlns="http://www.w3.org/1999/xhtml">
+        <p>paragraph</p>
+      </div>
+    </content>
+  </entry>
+</feed>';
+$dom->loadXML($xml);
+$entry = $dom->getElementsByTagNameNS("http://www.w3.org/2005/Atom", "entry")->item(0);
+$contentNode = $entry->getElementsByTagName("content")->item(0)->firstChild;
+$dateNode = $entry->getElementsByTagName("updated")->item(0)->firstChild;
+$contentNode->firstChild->insertBefore($dateNode);
+echo $dom->saveXML();
+?>
+--EXPECT--
+<?xml version="1.0" encoding="utf-8"?>
+<feed xmlns="http://www.w3.org/2005/Atom"><entry xmlns="http://www.w3.org/2005/Atom"><updated/><content><div xmlns="http://www.w3.org/1999/xhtml"><p>paragraph2007-02-14T00:00:00+01:00</p></div></content></entry></feed>