ownerDocument; if ($no instanceof DOMDocument) { $node->appendChild($no->createCDATASection($value)); } return $newChild; } /** * Adds a child element to the XML node with escaped $value if specified. Override of addChild method as * SimpleXMLElement's addChild method doesn't escape ampersand * * @param string $name — The name of the child element to add. * @param string $value — [optional] If specified, the value of the child element. * @param string $namespace [optional] If specified, the namespace to which the child element belongs. * @param boolean $escape [optional] The value is escaped by default, can be set to false. * * @return static The addChild method returns a SimpleXMLElement object representing the child added to the XML node. */ public function addChild($name, $value = null, $namespace = null, $escape = true): static { $newChild = parent::addChild($name, null, $namespace); $node = dom_import_simplexml($newChild); $no = $node->ownerDocument; $value = $escape ? esc($value ?? '') : $value ?? ''; if (! $no instanceof DOMDocument) { return $newChild; } if (is_array($value)) { return $newChild; } $node->appendChild($no->createTextNode($value)); return $newChild; } }