| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 | 
							- <?php
 
- /**
 
-  * Registry object that contains information about the current context.
 
-  * @warning Is a bit buggy when variables are set to null: it thinks
 
-  *          they don't exist! So use false instead, please.
 
-  * @note Since the variables Context deals with may not be objects,
 
-  *       references are very important here! Do not remove!
 
-  */
 
- class HTMLPurifier_Context
 
- {
 
-     /**
 
-      * Private array that stores the references.
 
-      * @type array
 
-      */
 
-     private $_storage = array();
 
-     /**
 
-      * Registers a variable into the context.
 
-      * @param string $name String name
 
-      * @param mixed $ref Reference to variable to be registered
 
-      */
 
-     public function register($name, &$ref)
 
-     {
 
-         if (array_key_exists($name, $this->_storage)) {
 
-             trigger_error(
 
-                 "Name $name produces collision, cannot re-register",
 
-                 E_USER_ERROR
 
-             );
 
-             return;
 
-         }
 
-         $this->_storage[$name] =& $ref;
 
-     }
 
-     /**
 
-      * Retrieves a variable reference from the context.
 
-      * @param string $name String name
 
-      * @param bool $ignore_error Boolean whether or not to ignore error
 
-      * @return mixed
 
-      */
 
-     public function &get($name, $ignore_error = false)
 
-     {
 
-         if (!array_key_exists($name, $this->_storage)) {
 
-             if (!$ignore_error) {
 
-                 trigger_error(
 
-                     "Attempted to retrieve non-existent variable $name",
 
-                     E_USER_ERROR
 
-                 );
 
-             }
 
-             $var = null; // so we can return by reference
 
-             return $var;
 
-         }
 
-         return $this->_storage[$name];
 
-     }
 
-     /**
 
-      * Destroys a variable in the context.
 
-      * @param string $name String name
 
-      */
 
-     public function destroy($name)
 
-     {
 
-         if (!array_key_exists($name, $this->_storage)) {
 
-             trigger_error(
 
-                 "Attempted to destroy non-existent variable $name",
 
-                 E_USER_ERROR
 
-             );
 
-             return;
 
-         }
 
-         unset($this->_storage[$name]);
 
-     }
 
-     /**
 
-      * Checks whether or not the variable exists.
 
-      * @param string $name String name
 
-      * @return bool
 
-      */
 
-     public function exists($name)
 
-     {
 
-         return array_key_exists($name, $this->_storage);
 
-     }
 
-     /**
 
-      * Loads a series of variables from an associative array
 
-      * @param array $context_array Assoc array of variables to load
 
-      */
 
-     public function loadArray($context_array)
 
-     {
 
-         foreach ($context_array as $key => $discard) {
 
-             $this->register($key, $context_array[$key]);
 
-         }
 
-     }
 
- }
 
- // vim: et sw=4 sts=4
 
 
  |