芝麻web文件管理V1.00
编辑当前文件:/home/strato/chroot/opt/RZphp5/includes/XML/Transformer/CallbackRegistry.php
and | // | Kristian Khntopp
. | // +---------------------------------------------------------------------------+ // | This source file is subject to version 3.00 of the PHP License, | // | that is available at http://www.php.net/license/3_0.txt. | // | If you did not receive a copy of the PHP license and are unable to | // | obtain it through the world-wide-web, please send a note to | // | license@php.net so we can mail you a copy immediately. | // +---------------------------------------------------------------------------+ // // $Id: CallbackRegistry.php,v 1.24 2004/12/22 08:06:12 sebastian Exp $ // /** * Callback Registry. * * @author Sebastian Bergmann
* @author Kristian Khntopp
* @copyright Copyright © 2002-2005 Sebastian Bergmann
and Kristian Khntopp
* @license http://www.php.net/license/3_0.txt The PHP License, Version 3.0 * @category XML * @package XML_Transformer */ class XML_Transformer_CallbackRegistry { // {{{ Members /** * @var array * @access public */ var $overloadedNamespaces = array(); /** * @var boolean * @access private */ var $_locked = FALSE; /** * If TRUE, the transformation will continue recursively * until the XML contains no more overloaded elements. * Can be overrided on a per-element basis. * * @var boolean * @access private */ var $_recursiveOperation = TRUE; // }}} // {{{ function XML_Transformer_CallbackRegistry($recursiveOperation) /** * Constructor. * * @param boolean * @access public */ function XML_Transformer_CallbackRegistry($recursiveOperation) { $this->_recursiveOperation = $recursiveOperation; } // }}} // {{{ function overloadNamespace($namespacePrefix, &$object, $recursiveOperation = '') /** * Overloads an XML Namespace. * * @param string * @param object * @param boolean * @return mixed * @access public */ function overloadNamespace($namespacePrefix, &$object, $recursiveOperation = '') { if (!is_object($object)) { return sprintf( 'Cannot overload namespace "%s", ' . 'second parameter is not an object.', $namespacePrefix ); } if (!is_subclass_of($object, 'XML_Transformer_Namespace')) { return sprintf( 'Cannot overload namespace "%s", ' . 'provided object was not instantiated from ' . 'a class that inherits XML_Transformer_Namespace.', $namespacePrefix ); } if (!method_exists($object, 'startElement') || !method_exists($object, 'endElement')) { return sprintf( 'Cannot overload namespace "%s", ' . 'method(s) "startElement" and/or "endElement" ' . 'are missing on given object.', $namespacePrefix ); } $this->overloadedNamespaces[$namespacePrefix]['active'] = TRUE; $this->overloadedNamespaces[$namespacePrefix]['object'] = &$object; $this->overloadedNamespaces[$namespacePrefix]['recursiveOperation'] = is_bool($recursiveOperation) ? $recursiveOperation : $this->_recursiveOperation; return TRUE; } // }}} // {{{ function unOverloadNamespace($namespacePrefix) /** * Reverts overloading of a given XML Namespace. * * @param string * @access public */ function unOverloadNamespace($namespacePrefix) { if (isset($this->overloadedNamespaces[$namespacePrefix])) { unset($this->overloadedNamespaces[$namespacePrefix]); } } // }}} // {{{ function isOverloadedNamespace($namespacePrefix) /** * Returns TRUE if a given namespace is overloaded, * FALSE otherwise. * * @param string * @return boolean * @access public */ function isOverloadedNamespace($namespacePrefix) { return isset( $this->overloadedNamespaces[$namespacePrefix] ); } // }}} // {{{ function setRecursiveOperation($recursiveOperation) /** * Enables or disables the recursive operation. * * @param boolean * @access public */ function setRecursiveOperation($recursiveOperation) { if (is_bool($recursiveOperation)) { $this->_recursiveOperation = $recursiveOperation; } } // }}} // {{{ function function getLock($namespace) /** * Lock all namespace handlers except a given one. * * @string namespace * @return boolean * @access public * @see releaseLock() */ function getLock($namespace) { if (!$this->_locked) { $namespacePrefixes = array_keys($this->overloadedNamespaces); foreach ($namespacePrefixes as $namespacePrefix) { if ($namespacePrefix != $namespace) { unset($this->overloadedNamespaces[$namespacePrefix]['active']); } } $this->_locked = TRUE; return TRUE; } return FALSE; } // }}} // {{{ function releaseLock() /** * Releases a lock. * * @access public * @see getLock() */ function releaseLock() { $namespacePrefixes = array_keys($this->overloadedNamespaces); foreach ($namespacePrefixes as $namespacePrefix) { $this->overloadedNamespaces[$namespacePrefix]['active'] = TRUE; } $this->_locked = FALSE; } // }}} } /* * vim600: et sw=2 ts=2 fdm=marker * vim<600: et sw=2 ts=2 */ ?>