X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=php5%2Fxml-template.php;h=e6f92c21888135ef9038a9d79965a85f7d67a5aa;hb=19ada1f1ca1872cfe3210d62b0633702b8d46f51;hp=6fbf4bf8962c246740c619045985d176be34dae4;hpb=bcaa7bbbb271d7d83017218b5e2965c239aaad8d;p=xml-template diff --git a/php5/xml-template.php b/php5/xml-template.php index 6fbf4bf..e6f92c2 100644 --- a/php5/xml-template.php +++ b/php5/xml-template.php @@ -2,7 +2,8 @@ function XML_Template_process_file($filename, $obj, $clean = 1) { - $doc = domxml_open_file($filename); + $doc = new DOMDocument; + $doc->load($filename); XML_Template_process($doc, $obj, $clean); return $doc; } @@ -10,39 +11,42 @@ function XML_Template_process_file($filename, $obj, $clean = 1) function XML_Template_process($node, $obj, $clean = 1) { if (is_a($obj, 'domnode')) { # overwrite - foreach ($node->child_nodes() as $child) { - $node->remove_child($child); + for ($i = 0; $i < $node->childNodes->length; ++$i) { + $child = $node->childNodes->item($i); + $node->removeChild($child); } if (is_a($obj, 'domdocument')) { $obj = $obj->document_element(); } - $newobj = own_clone_node($obj, $node->owner_document()); - $node->append_child($newobj); + $newobj = own_clone_node($obj, $node->ownerDocument); + $node->appendChild($newobj); XML_Template_process($newobj, array(), $clean); } else if (!is_array($obj)) { # overwrite - foreach ($node->child_nodes() as $child) { - $node->remove_child($child); + for ($i = 0; $i < $node->childNodes->length; ++$i) { + $child = $node->childNodes->item($i); + $node->removeChild($child); } - $doc = $node->owner_document(); - $node->add_child($doc->create_text_node($obj)); + $doc = $node->ownerDocument; + $node->appendChild($doc->createTextNode($obj)); } else if (is_associative_array($obj)) { # substitute - foreach ($node->child_nodes() as $child) { + for ($i = 0; $i < $node->childNodes->length; ++$i) { + $child = $node->childNodes->item($i); $processed = false; - if ($child->node_type() == XML_ELEMENT_NODE) { + if ($child->nodeType == XML_ELEMENT_NODE) { unset($id); - $tag = $child->node_name(); - $attrs = $child->attributes(); + $tag = $child->nodeName; + $attrs = $child->attributes; if (isset($attrs)) { - foreach ($child->attributes() as $attr) { - if ($attr->namespace_uri() == 'http://template.sesse.net/' && $attr->name() == 'id') { - $id = $attr->value(); + foreach ($child->attributes as $attr) { + if ($attr->namespaceURI == 'http://template.sesse.net/' && $attr->name == 'id') { + $id = $attr->value; if ($clean) { - $attr->unlink_node(); + # $attr->unlinkNode(); } } } @@ -72,12 +76,13 @@ function XML_Template_process($node, $obj, $clean = 1) } } } else { # repeat - $doc = $node->owner_document(); - $frag = $doc->create_element("temporary-fragment"); # ugh + $doc = $node->ownerDocument; + $frag = $doc->createElement("temporary-fragment"); # ugh - foreach ($node->child_nodes() as $child) { - $frag->append_child($child); - $node->remove_child($child); + for ($i = 0; $i < $node->childNodes->length; ++$i) { + $child = $node->childNodes->item($i); + $frag->appendChild($child); + $node->removeChild($child); } foreach ($obj as $instance) { @@ -85,8 +90,8 @@ function XML_Template_process($node, $obj, $clean = 1) continue; } - $newnode = own_clone_node($frag, $frag->owner_document()); - $node->append_child($newnode); + $newnode = own_clone_node($frag, $frag->ownerDocument); + $node->appendChild($newnode); XML_Template_process($newnode, $instance, $clean); if ($clean) { XML_Template_clean($newnode); @@ -95,14 +100,16 @@ function XML_Template_process($node, $obj, $clean = 1) # remove all the tags - foreach ($node->child_nodes() as $child) { - if ($child->name() != 'temporary-fragment') { + for ($i = 0; $i < $node->childNodes->length; ++$i) { + $child = $node->childNodes->item($i); + if ($child->name != 'temporary-fragment') { continue; } - foreach ($child->child_nodes() as $child2) { - $node->append_child($child2); + for ($j = 0; $j < $child->childNodes->length; ++$j) { + $child2 = $child->childNodes->item($j); + $node->appendChild($child2); } - $node->remove_child($child); + $node->removeChild($child); } } @@ -113,20 +120,21 @@ function XML_Template_process($node, $obj, $clean = 1) function XML_Template_clean($node) { - if ($node->node_type() == XML_ELEMENT_NODE) { - if ($node->namespace_uri() != 'http://template.sesse.net/') { + if ($node->nodeType == XML_ELEMENT_NODE) { + if ($node->namespaceURI != 'http://template.sesse.net/') { return; } # as this is a dummy node, we want to remove it and move everything further up # after we've done any required replacements - $doc = $node->owner_document(); - $parent = $node->parent_node(); - foreach ($node->child_nodes() as $child) { - $node->remove_child($child); + $doc = $node->ownerDocument; + $parent = $node->parentNode; + for ($i = 0; $i < $node->childNodes->length; ++$i) { + $child = $node->childNodes->item($i); + $node->removeChild($child); $node->insert_before($child, $node); } - $parent->remove_child($node); + $parent->removeChild($node); } } @@ -150,27 +158,28 @@ function XML_Template_alternate($tag, $array, $elems) function own_clone_node($node, $doc) { // we only need these two - if ($node->node_type() == XML_ELEMENT_NODE) { - $nsuri = $node->namespace_uri(); + if ($node->nodeType == XML_ELEMENT_NODE) { + $nsuri = $node->namespaceURI; if (isset($nsuri)) { - $newnode = $doc->create_element_ns($node->namespace_uri(), $node->node_name(), $node->prefix()); + $newnode = $doc->createElementNS($node->namespaceURI, $node->nodeName, $node->prefix()); } else { - $newnode = $doc->create_element($node->node_name()); + $newnode = $doc->createElement($node->nodeName); } - $attrs = $node->attributes(); + $attrs = $node->attributes; if (isset($attrs)) { - foreach ($node->attributes() as $attr) { - $attr2 = $doc->create_attribute($attr->name(), $attr->value()); - $nsuri = $attr->namespace_uri(); + foreach ($node->attributes as $attr) { + $attr2 = $doc->createAttribute($attr->name, $attr->value); + $nsuri = $attr->namespaceURI; if (isset($nsuri)) { - $attr2->set_namespace($nsuri, $attr->prefix()); + $attr2->set_namespace($nsuri, $attr->prefix); } - $newnode->append_child($attr2); + $newnode->appendChild($attr2); } } - foreach ($node->child_nodes() as $child) { - $newnode->append_child(own_clone_node($child, $doc)); + for ($i = 0; $i < $node->childNodes->length; ++$i) { + $child = $node->childNodes->item($i); + $newnode->appendChild(own_clone_node($child, $doc)); } return $newnode; } else {