X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=php5%2Fxml-template.php;h=66937d24e4a9e59b8b4fc842daecc14151d95767;hb=c1d4dfa5fe43d3e229cd90a18975fbf4df120f50;hp=e8ac72e79d44e6bb1c273ff01f306ee5990941cb;hpb=46a9eedcf6b7b7f3d87c3f48259884ba1c162ba1;p=xml-template diff --git a/php5/xml-template.php b/php5/xml-template.php index e8ac72e..66937d2 100644 --- a/php5/xml-template.php +++ b/php5/xml-template.php @@ -20,10 +20,10 @@ function XML_Template_process($node, $obj, $clean = 1) $obj = $obj->documentElement; } - $newobj = $obj->cloneNode(true); - $node->apendChild($newobj); - - XML_Template_process($newobj, array(), $clean); + $frag = $node->ownerDocument->createDocumentFragment(); + $frag->appendXML($obj->ownerDocument->saveXML($obj)); + XML_Template_process($frag, array(), $clean); + $node->appendChild($frag); } else if (!is_array($obj)) { # overwrite for ($i = 0; $i < $node->childNodes->length; ++$i) { $child = $node->childNodes->item($i); @@ -91,8 +91,9 @@ function XML_Template_process($node, $obj, $clean = 1) continue; } - $newnode = $frag->cloneNode(true); + $newnode = own_clone_node($frag, $frag->ownerDocument); XML_Template_process($newnode, $instance, $clean); + $node->appendChild($newnode); if ($clean) { XML_Template_clean($newnode); @@ -140,6 +141,52 @@ function XML_Template_alternate($tag, $array, $elems) return $array; } +# Ideally, this would be "return $obj->clone_node(true)". But surprise, surprise, +# PHP is buggy (at least both PHP4 and PHP5); it removes the prefix information +# from all attributes during a clone. IOW, we'll have to clone evverything +# ourselves. +function own_clone_node($node, $doc) +{ + // we only need these two + if ($node->nodeType == XML_DOCUMENT_FRAG_NODE) { + $newnode = $doc->createDocumentFragment(); + + for ($i = 0; $i < $node->childNodes->length; ++$i) { + $child = $node->childNodes->item($i); + $newnode->appendChild(own_clone_node($child, $doc)); + } + return $newnode; + } else if ($node->nodeType == XML_ELEMENT_NODE) { + $nsuri = $node->namespaceURI; + if (isset($nsuri) && $node->prefix != "default") { + $newnode = $doc->createElementNS($node->namespaceURI, $node->nodeName, $node->prefix); + } else { + $newnode = $doc->createElement($node->localName); + } + + $attrs = $node->attributes; + if (isset($attrs)) { + foreach ($node->attributes as $attr) { + $nsuri = $attr->namespaceURI; + if (isset($nsuri) && $attr->prefix != "default") { + $attr2 = $doc->createAttributeNS($nsuri, $attr->prefix . ":" . $attr->name); + } else { + $attr2 = $doc->createAttribute($attr->localName); + } + $attr2->value = $attr->value; + $newnode->appendChild($attr2); + } + } + for ($i = 0; $i < $node->childNodes->length; ++$i) { + $child = $node->childNodes->item($i); + $newnode->appendChild(own_clone_node($child, $doc)); + } + return $newnode; + } else { + return $node->cloneNode(true); + } +} + function is_associative_array($arr) { if (!is_array($arr)) {