php-src/ext/simplexml
Christian Stocker e1813b69c5 Merge from Trunk
simplexml->query returns empty array if no nodes were found
and false if libxml thinks the xpath-expression was invalid.
Behaves now the same like DomXPath and fixes Bug #48601
Adjusted a test to reflect that change
2011-09-01 13:42:45 +00:00
..
examples update the examples 2004-01-17 21:44:22 +00:00
tests Merge from Trunk 2011-09-01 13:42:45 +00:00
config.m4 MFH: Fix #45976 (Move SXE from SPL to SimpleXML) 2008-11-06 00:37:13 +00:00
config.w32 Fix assignment when SimpleXML is disabled on Windows 2010-02-25 17:08:17 +00:00
CREDITS Fix writing of SQLite and SimpleXMl extension and add Rob to the credits 2004-03-28 20:27:18 +00:00
php_simplexml_exports.h - Year++ 2011-01-01 02:19:59 +00:00
php_simplexml.h - Year++ 2011-01-01 02:19:59 +00:00
README - Fix typoes 2004-01-17 20:20:18 +00:00
simplexml.c Merge from Trunk 2011-09-01 13:42:45 +00:00
simplexml.dsp - Renamed all *php4* files to *php5*, changed all php4/PHP4 to php5/PHP5 2004-01-17 13:00:38 +00:00
sxe.c - Added missing arginfos for void params and void param checks 2011-06-18 15:56:14 +00:00
sxe.h - Year++ 2011-01-01 02:19:59 +00:00

SimpleXML is meant to be an easy way to access XML data.

SimpleXML objects follow four basic rules:

1) properties denote element iterators
2) numeric indices denote elements
3) non numeric indices denote attributes
4) string conversion allows to access TEXT data

When iterating properties then the extension always iterates over
all nodes with that element name. Thus method children() must be 
called to iterate over subnodes. But also doing the following:
foreach ($obj->node_name as $elem) {
  // do something with $elem
}
always results in iteration of 'node_name' elements. So no further 
check is needed to distinguish the number of nodes of that type.

When an elements TEXT data is being accessed through a property
then the result does not include the TEXT data of subelements.

Known issues
============

Due to engine problems it is currently not possible to access
a subelement by index 0: $object->property[0].

TODO
====

At the moment property access to multiple elements of the same
name returns an array of SimpleXML objects. This should be an 
object of a new type instead so that all kinds of linkage,
assignment and deleting would work.