48 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| /**
 | |
|  * This is in almost every respect equivalent to an array except
 | |
|  * that it keeps track of which keys were accessed.
 | |
|  *
 | |
|  * @warning For the sake of backwards compatibility with early versions
 | |
|  *     of PHP 5, you must not use the $hash[$key] syntax; if you do
 | |
|  *     our version of offsetGet is never called.
 | |
|  */
 | |
| class HTMLPurifier_StringHash extends ArrayObject
 | |
| {
 | |
|     /**
 | |
|      * @type array
 | |
|      */
 | |
|     protected $accessed = array();
 | |
| 
 | |
|     /**
 | |
|      * Retrieves a value, and logs the access.
 | |
|      * @param mixed $index
 | |
|      * @return mixed
 | |
|      */
 | |
|     public function offsetGet($index)
 | |
|     {
 | |
|         $this->accessed[$index] = true;
 | |
|         return parent::offsetGet($index);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Returns a lookup array of all array indexes that have been accessed.
 | |
|      * @return array in form array($index => true).
 | |
|      */
 | |
|     public function getAccessed()
 | |
|     {
 | |
|         return $this->accessed;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Resets the access array.
 | |
|      */
 | |
|     public function resetAccessed()
 | |
|     {
 | |
|         $this->accessed = array();
 | |
|     }
 | |
| }
 | |
| 
 | |
| // vim: et sw=4 sts=4
 |