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;
- }
- }
- }
- }
|