(PHP 3 >= 3.0.8, PHP 4, PHP 5)
xml_parse_into_struct -- Parse XML data into an array structure
Description
int 
xml_parse_into_struct ( resource parser, string data, array &values [, array &index] )
     This function parses an XML file into 2 parallel array
     structures, one (index) containing pointers 
     to the location of the appropriate values in the
     values array. These last two parameters
     must be passed by reference.
    
Note: 
      xml_parse_into_struct() returns 0 for 
      failure and 1 for success. This is not the same as FALSE 
      and TRUE, be careful with operators such as ===.
     
     Below is an example that illustrates the internal structure of
     the arrays being generated by the function. We use a simple
     note tag embedded inside a
     para tag, and then we parse this and print out
     the structures generated:
     
| Example 1. xml_parse_into_struct() example | 
<?php$simple = "<para><note>simple note</note></para>";
 $p = xml_parser_create();
 xml_parse_into_struct($p, $simple, $vals, $index);
 xml_parser_free($p);
 echo "Index array\n";
 print_r($index);
 echo "\nVals array\n";
 print_r($vals);
 ?>
 | 
 
       When we run that code, the output will be:
       | Index array
Array
(
    [PARA] => Array
        (
            [0] => 0
            [1] => 2
        )
    [NOTE] => Array
        (
            [0] => 1
        )
)
Vals array
Array
(
    [0] => Array
        (
            [tag] => PARA
            [type] => open
            [level] => 1
        )
    [1] => Array
        (
            [tag] => NOTE
            [type] => complete
            [level] => 2
            [value] => simple note
        )
    [2] => Array
        (
            [tag] => PARA
            [type] => close
            [level] => 1
        )
) | 
 | 
    
     Event-driven parsing (based on the expat library) can get
     complicated when you have an XML document that is complex.
     This function does not produce a DOM style object, but it
     generates structures amenable of being transversed in a tree
     fashion. Thus, we can create objects representing the data
     in the XML file easily. Let's consider the following XML file
     representing a small database of aminoacids information:
     
| Example 2. moldb.xml - small database of molecular information | <?xml version="1.0"?>
<moldb>
    <molecule>
        <name>Alanine</name>
        <symbol>ala</symbol>
        <code>A</code>
        <type>hydrophobic</type>
    </molecule>
    <molecule>
        <name>Lysine</name>
        <symbol>lys</symbol>
        <code>K</code>
        <type>charged</type>
    </molecule>
</moldb> | 
 | 
     And some code to parse the document and generate the appropriate
     objects:
     
| Example 3. 
       parsemoldb.php - parses moldb.xml into an array of
       molecular objects
       | 
<?php
 class AminoAcid {
 var $name;  // aa name
 var $symbol;    // three letter symbol
 var $code;  // one letter code
 var $type;  // hydrophobic, charged or neutral
 
 function AminoAcid ($aa)
 {
 foreach ($aa as $k=>$v)
 $this->$k = $aa[$k];
 }
 }
 
 function readDatabase($filename)
 {
 // read the XML database of aminoacids
 $data = implode("", file($filename));
 $parser = xml_parser_create();
 xml_parser_set_option($parser, XML_OPTION_CASE_FOLDING, 0);
 xml_parser_set_option($parser, XML_OPTION_SKIP_WHITE, 1);
 xml_parse_into_struct($parser, $data, $values, $tags);
 xml_parser_free($parser);
 
 // loop through the structures
 foreach ($tags as $key=>$val) {
 if ($key == "molecule") {
 $molranges = $val;
 // each contiguous pair of array entries are the
 // lower and upper range for each molecule definition
 for ($i=0; $i < count($molranges); $i+=2) {
 $offset = $molranges[$i] + 1;
 $len = $molranges[$i + 1] - $offset;
 $tdb[] = parseMol(array_slice($values, $offset, $len));
 }
 } else {
 continue;
 }
 }
 return $tdb;
 }
 
 function parseMol($mvalues)
 {
 for ($i=0; $i < count($mvalues); $i++) {
 $mol[$mvalues[$i]["tag"]] = $mvalues[$i]["value"];
 }
 return new AminoAcid($mol);
 }
 
 $db = readDatabase("moldb.xml");
 echo "** Database of AminoAcid objects:\n";
 print_r($db);
 
 ?>
 | 
 | 
     After executing 
parsemoldb.php, the variable
     
$db contains an array of
     
AminoAcid objects, and the output of the
     script confirms that: