| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179 | 
							- <?php
 
- namespace PhpOffice\PhpSpreadsheet;
 
- class HashTable
 
- {
 
-     /**
 
-      * HashTable elements.
 
-      *
 
-      * @var IComparable[]
 
-      */
 
-     protected $items = [];
 
-     /**
 
-      * HashTable key map.
 
-      *
 
-      * @var string[]
 
-      */
 
-     protected $keyMap = [];
 
-     /**
 
-      * Create a new \PhpOffice\PhpSpreadsheet\HashTable.
 
-      *
 
-      * @param IComparable[] $pSource Optional source array to create HashTable from
 
-      *
 
-      * @throws Exception
 
-      */
 
-     public function __construct($pSource = null)
 
-     {
 
-         if ($pSource !== null) {
 
-             // Create HashTable
 
-             $this->addFromSource($pSource);
 
-         }
 
-     }
 
-     /**
 
-      * Add HashTable items from source.
 
-      *
 
-      * @param IComparable[] $pSource Source array to create HashTable from
 
-      *
 
-      * @throws Exception
 
-      */
 
-     public function addFromSource(array $pSource = null)
 
-     {
 
-         // Check if an array was passed
 
-         if ($pSource == null) {
 
-             return;
 
-         }
 
-         foreach ($pSource as $item) {
 
-             $this->add($item);
 
-         }
 
-     }
 
-     /**
 
-      * Add HashTable item.
 
-      *
 
-      * @param IComparable $pSource Item to add
 
-      */
 
-     public function add(IComparable $pSource)
 
-     {
 
-         $hash = $pSource->getHashCode();
 
-         if (!isset($this->items[$hash])) {
 
-             $this->items[$hash] = $pSource;
 
-             $this->keyMap[count($this->items) - 1] = $hash;
 
-         }
 
-     }
 
-     /**
 
-      * Remove HashTable item.
 
-      *
 
-      * @param IComparable $pSource Item to remove
 
-      */
 
-     public function remove(IComparable $pSource)
 
-     {
 
-         $hash = $pSource->getHashCode();
 
-         if (isset($this->items[$hash])) {
 
-             unset($this->items[$hash]);
 
-             $deleteKey = -1;
 
-             foreach ($this->keyMap as $key => $value) {
 
-                 if ($deleteKey >= 0) {
 
-                     $this->keyMap[$key - 1] = $value;
 
-                 }
 
-                 if ($value == $hash) {
 
-                     $deleteKey = $key;
 
-                 }
 
-             }
 
-             unset($this->keyMap[count($this->keyMap) - 1]);
 
-         }
 
-     }
 
-     /**
 
-      * Clear HashTable.
 
-      */
 
-     public function clear()
 
-     {
 
-         $this->items = [];
 
-         $this->keyMap = [];
 
-     }
 
-     /**
 
-      * Count.
 
-      *
 
-      * @return int
 
-      */
 
-     public function count()
 
-     {
 
-         return count($this->items);
 
-     }
 
-     /**
 
-      * Get index for hash code.
 
-      *
 
-      * @param string $pHashCode
 
-      *
 
-      * @return int Index
 
-      */
 
-     public function getIndexForHashCode($pHashCode)
 
-     {
 
-         return array_search($pHashCode, $this->keyMap);
 
-     }
 
-     /**
 
-      * Get by index.
 
-      *
 
-      * @param int $pIndex
 
-      *
 
-      * @return IComparable
 
-      */
 
-     public function getByIndex($pIndex)
 
-     {
 
-         if (isset($this->keyMap[$pIndex])) {
 
-             return $this->getByHashCode($this->keyMap[$pIndex]);
 
-         }
 
-         return null;
 
-     }
 
-     /**
 
-      * Get by hashcode.
 
-      *
 
-      * @param string $pHashCode
 
-      *
 
-      * @return IComparable
 
-      */
 
-     public function getByHashCode($pHashCode)
 
-     {
 
-         if (isset($this->items[$pHashCode])) {
 
-             return $this->items[$pHashCode];
 
-         }
 
-         return null;
 
-     }
 
-     /**
 
-      * HashTable to array.
 
-      *
 
-      * @return IComparable[]
 
-      */
 
-     public function toArray()
 
-     {
 
-         return $this->items;
 
-     }
 
-     /**
 
-      * Implement PHP __clone to create a deep clone, not just a shallow copy.
 
-      */
 
-     public function __clone()
 
-     {
 
-         $vars = get_object_vars($this);
 
-         foreach ($vars as $key => $value) {
 
-             if (is_object($value)) {
 
-                 $this->$key = clone $value;
 
-             }
 
-         }
 
-     }
 
- }
 
 
  |