HEX
Server: Apache
System: Linux webm004.cluster121.gra.hosting.ovh.net 5.15.167-ovh-vps-grsec-zfs-classid #1 SMP Tue Sep 17 08:14:20 UTC 2024 x86_64
User: grainesdfo (155059)
PHP: 5.4.45
Disabled: _dyuweyrj4,_dyuweyrj4r,dl
Upload Files
File: /home/grainesdfo/www/wp-content/plugins/tablepress/libraries/vendor/PhpSpreadsheet/HashTable.php
<?php

namespace TablePress\PhpOffice\PhpSpreadsheet;

/**
 * @template T of IComparable
 */
class HashTable
{
	/**
	 * HashTable elements.
	 *
	 * @var array<string, T>
	 */
	protected array $items = [];

	/**
	 * HashTable key map.
	 *
	 * @var array<int, string>
	 */
	protected array $keyMap = [];

	/**
	 * Create a new HashTable.
	 *
	 * @param T[] $source Optional source array to create HashTable from
	 */
	public function __construct(?array $source = [])
	{
		if ($source !== null) {
			// Create HashTable
			$this->addFromSource($source);
		}
	}

	/**
	 * Add HashTable items from source.
	 *
	 * @param T[] $source Source array to create HashTable from
	 */
	public function addFromSource(?array $source = null): void
	{
		// Check if an array was passed
		if ($source === null) {
			return;
		}

		foreach ($source as $item) {
			$this->add($item);
		}
	}

	/**
	 * Add HashTable item.
	 *
	 * @param T $source Item to add
	 */
	public function add(IComparable $source): void
	{
		$hash = $source->getHashCode();
		if (!isset($this->items[$hash])) {
			$this->items[$hash] = $source;
			$this->keyMap[count($this->items) - 1] = $hash;
		}
	}

	/**
	 * Remove HashTable item.
	 *
	 * @param T $source Item to remove
	 */
	public function remove(IComparable $source): void
	{
		$hash = $source->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(): void
	{
		$this->items = [];
		$this->keyMap = [];
	}

	/**
	 * Count.
	 */
	public function count(): int
	{
		return count($this->items);
	}

	/**
				 * Get index for hash code.
				 * @return int|false
				 */
				public function getIndexForHashCode(string $hashCode)
	{
		return array_search($hashCode, $this->keyMap, true);
	}

	/**
	 * Get by index.
	 *
	 * @return null|T
	 */
	public function getByIndex(int $index): ?IComparable
	{
		if (isset($this->keyMap[$index])) {
			return $this->getByHashCode($this->keyMap[$index]);
		}

		return null;
	}

	/**
	 * Get by hashcode.
	 *
	 * @return null|T
	 */
	public function getByHashCode(string $hashCode): ?IComparable
	{
		if (isset($this->items[$hashCode])) {
			return $this->items[$hashCode];
		}

		return null;
	}

	/**
	 * HashTable to array.
	 *
	 * @return T[]
	 */
	public function toArray(): array
	{
		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) {
			// each member of this class is an array
			if (is_array($value)) {
				$array1 = $value;
				foreach ($array1 as $key1 => $value1) {
					if (is_object($value1)) {
						$array1[$key1] = clone $value1;
					}
				}
				$this->$key = $array1;
			}
		}
	}
}