Note to tudor:
You can't override the constructor, but you can get around that with a simple static method:
<?php
class simpleXmlExtender extends SimpleXMLElement {
public static function _new($xml=NULL, $ns=NULL, $prefix=TRUE) {
// allows you to set certain option parameters to new default values,
// or automatically decide whether input data is a file or not
// optionally, you can save the object in an intermediate variable
// and peform other actions on/with it before returning it
return new simpleXmlExtender($xml, LIBXML_NOCDATA, file_exists($xml), $ns, $prefix);
}
}
$simpleXML = simpleXmlExtender::_new($xmldata);
?>
... it's a bit of a hack, but it works.
SimpleXMLElement->__construct
(No version information available, might be only in CVS)
SimpleXMLElement->__construct — Creates a new SimpleXMLElement object
Description
Creates a new SimpleXMLElement object.
Parameters
- data
-
A well-formed XML string or the path or URL to an XML document if data_is_url is TRUE.
- options
-
Optionally used to specify additional Libxml parameters.
- data_is_url
-
By default, data_is_url is FALSE. Use TRUE to specify that data is a path or URL to an XML document instead of string data.
- ns
-
- is_prefix
-
Return Values
Returns a SimpleXMLElement object representing data .
Errors/Exceptions
Produces an E_WARNING error message for each error found in the XML data and throws an exception if errors were detected.
Examples
Example #1 Create a SimpleXMLElement object
<?php
include 'example.php';
$sxe = new SimpleXMLElement($xmlstr);
echo $sxe->movie[0]->title;
?>
Example #2 Create a SimpleXMLElement object from a URL
<?php
$sxe = new SimpleXMLElement('http://example.org/document.xml', NULL, TRUE);
echo $sxe->asXML();
?>
SimpleXMLElement->__construct
06-Nov-2008 03:12
30-Sep-2008 01:42
A note about the undocumented parameters:
$ns (string): namespace prefix or URI
$is_prefix (bool): TRUE if $ns is a prefix, FALSE if it's a URI; defaults to FALSE
E.g.:
<?php
$xml_string = '<xml xmlns:foo='uuid:BDC6E3F0-6DA3-11d1-A2A3-00AA00C14882'>
<foo:bar>..................';
$a = new SimpleXMLElement($xml_string, NULL, FALSE, 'foo', TRUE);
$b = new SimpleXMLElement($xml_string, NULL, FALSE, 'uuid:BDC6E3F0-6DA3-11d1-A2A3-00AA00C14882', FALSE);
?>
However, I don't know exactly what these parameters are used for. They don't seem to be of much help when dealing with namespaces :-?
20-Nov-2007 03:35
This class is extendable, but it's too bad that its constructor cannot be overriden (PHP says it's a final method). Thus the class should be wrapped using the delegation principle rather that extended.
