132 lines
3.5 KiB
PHP
132 lines
3.5 KiB
PHP
|
<?php
|
||
|
/**
|
||
|
* MiniXML - PHP class library for generating and parsing XML.
|
||
|
*
|
||
|
* @package miniXML
|
||
|
* @author Patrick Deegan, Psychogenic.com
|
||
|
* @license GPL
|
||
|
*/
|
||
|
/*
|
||
|
CONFIGURATION
|
||
|
Please see the http://minixml.psychogenic.com website for details on these configuration
|
||
|
options.
|
||
|
*/
|
||
|
|
||
|
|
||
|
/* All config options can be set to 0 (off) or 1 (on) */
|
||
|
|
||
|
define("MINIXML_CASESENSITIVE", 0); /* Set to 1 to use case sensitive element name comparisons */
|
||
|
|
||
|
define("MINIXML_AUTOESCAPE_ENTITIES", 1); /* Set to 1 to autoescape stuff like > and < and & in text, 0 to turn it off */
|
||
|
|
||
|
|
||
|
|
||
|
define("MINIXML_AUTOSETPARENT", 0); /* Set to 1 to automatically register parents elements with children */
|
||
|
|
||
|
define("MINIXML_AVOIDLOOPS", 0); /* Set to 1 to set the default behavior of 'avoidLoops' to ON, 0 otherwise */
|
||
|
|
||
|
define("MINIXML_IGNOREWHITESPACES", 1); /* Set to 1 to eliminate leading and trailing whitespaces from strings */
|
||
|
|
||
|
|
||
|
/* Lower/upper case attribute names. Choose UPPER or LOWER or neither - not both... UPPER takes precedence */
|
||
|
define("MINIXML_UPPERCASEATTRIBUTES", 0); /* Set to 1 to UPPERCASE all attributes, 0 otherwise */
|
||
|
define("MINIXML_LOWERCASEATTRIBUTES", 0); /* Set to 1 to lowercase all attributes, 0 otherwise */
|
||
|
|
||
|
|
||
|
/* fromFile cache.
|
||
|
** If you are using lots of $xmlDoc->fromFile('path/to/file.xml') calls, it is possible to use
|
||
|
** a caching mechanism. This cache will read the file, store a serialized version of the resulting
|
||
|
** object and read in the serialize object on subsequent calls.
|
||
|
**
|
||
|
** If the original XML file is updated, the cache will automatically be refreshed.
|
||
|
**
|
||
|
** To use caching, set MINIXML_USEFROMFILECACHING to 1 and set the
|
||
|
** MINIXML_FROMFILECACHEDIR to a suitable directory in which the cache files will
|
||
|
** be stored (eg, "/tmp")
|
||
|
**/
|
||
|
define("MINIXML_USEFROMFILECACHING", 0);
|
||
|
define("MINIXML_FROMFILECACHEDIR", "/tmp");
|
||
|
|
||
|
|
||
|
define("MINIXML_DEBUG", 0); /* Set Debug to 1 for more verbose output, 0 otherwise */
|
||
|
|
||
|
|
||
|
/***************************************** end Configuration ***************************************/
|
||
|
|
||
|
define("MINIXML_USE_SIMPLE", 0);
|
||
|
|
||
|
define("MINIXML_VERSION", "1.3.0"); /* Version information */
|
||
|
|
||
|
define("MINIXML_NOWHITESPACES", -999); /* Flag that may be passed to the toString() methods */
|
||
|
|
||
|
|
||
|
|
||
|
$MiniXMLLocation = dirname(__FILE__);
|
||
|
define("MINIXML_CLASSDIR", "$MiniXMLLocation/classes");
|
||
|
require_once(MINIXML_CLASSDIR . "/doc.inc.php");
|
||
|
|
||
|
|
||
|
/***************************************************************************************************
|
||
|
****************************************************************************************************
|
||
|
*****
|
||
|
***** Global Helper functions
|
||
|
*****
|
||
|
****************************************************************************************************
|
||
|
***************************************************************************************************/
|
||
|
|
||
|
|
||
|
function _MiniXMLLog ($message)
|
||
|
{
|
||
|
error_log("MiniXML LOG MESSAGE:\n$message\n");
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
function _MiniXMLError ($message)
|
||
|
{
|
||
|
error_log("MiniXML ERROR:\n$message\n");
|
||
|
|
||
|
return NULL;
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
function _MiniXML_NumKeyArray (&$v)
|
||
|
{
|
||
|
if (! is_array($v))
|
||
|
{
|
||
|
return NULL;
|
||
|
}
|
||
|
|
||
|
|
||
|
$arrayKeys = array_keys($v);
|
||
|
$numKeys = count($arrayKeys);
|
||
|
$totalNumeric = 0;
|
||
|
for($i=0; $i<$numKeys; $i++)
|
||
|
{
|
||
|
if (is_numeric($arrayKeys[$i]) && $arrayKeys[$i] == $i)
|
||
|
{
|
||
|
$totalNumeric++;
|
||
|
} else {
|
||
|
return 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if ($totalNumeric == $numKeys)
|
||
|
{
|
||
|
// All numeric - assume it is a "straight" array
|
||
|
return 1;
|
||
|
} else {
|
||
|
return 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
?>
|