| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 | 
							- <?php
 
- /**
 
-  * @link http://www.yiiframework.com/
 
-  * @copyright Copyright (c) 2008 Yii Software LLC
 
-  * @license http://www.yiiframework.com/license/
 
-  */
 
- namespace yii\base;
 
- /**
 
-  * ArrayAccessTrait provides the implementation for [[\IteratorAggregate]], [[\ArrayAccess]] and [[\Countable]].
 
-  *
 
-  * Note that ArrayAccessTrait requires the class using it contain a property named `data` which should be an array.
 
-  * The data will be exposed by ArrayAccessTrait to support accessing the class object like an array.
 
-  *
 
-  * @property array $data
 
-  *
 
-  * @author Qiang Xue <qiang.xue@gmail.com>
 
-  * @since 2.0
 
-  */
 
- trait ArrayAccessTrait
 
- {
 
-     /**
 
-      * Returns an iterator for traversing the data.
 
-      * This method is required by the SPL interface [[\IteratorAggregate]].
 
-      * It will be implicitly called when you use `foreach` to traverse the collection.
 
-      * @return \ArrayIterator an iterator for traversing the cookies in the collection.
 
-      */
 
-     public function getIterator()
 
-     {
 
-         return new \ArrayIterator($this->data);
 
-     }
 
-     /**
 
-      * Returns the number of data items.
 
-      * This method is required by Countable interface.
 
-      * @return int number of data elements.
 
-      */
 
-     public function count()
 
-     {
 
-         return count($this->data);
 
-     }
 
-     /**
 
-      * This method is required by the interface [[\ArrayAccess]].
 
-      * @param mixed $offset the offset to check on
 
-      * @return bool
 
-      */
 
-     public function offsetExists($offset)
 
-     {
 
-         return isset($this->data[$offset]);
 
-     }
 
-     /**
 
-      * This method is required by the interface [[\ArrayAccess]].
 
-      * @param int $offset the offset to retrieve element.
 
-      * @return mixed the element at the offset, null if no element is found at the offset
 
-      */
 
-     public function offsetGet($offset)
 
-     {
 
-         return isset($this->data[$offset]) ? $this->data[$offset] : null;
 
-     }
 
-     /**
 
-      * This method is required by the interface [[\ArrayAccess]].
 
-      * @param int $offset the offset to set element
 
-      * @param mixed $item the element value
 
-      */
 
-     public function offsetSet($offset, $item)
 
-     {
 
-         $this->data[$offset] = $item;
 
-     }
 
-     /**
 
-      * This method is required by the interface [[\ArrayAccess]].
 
-      * @param mixed $offset the offset to unset element
 
-      */
 
-     public function offsetUnset($offset)
 
-     {
 
-         unset($this->data[$offset]);
 
-     }
 
- }
 
 
  |