2022-07-05 15:55:47 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace DNW\Skills;
|
2010-09-25 18:25:56 -04:00
|
|
|
|
2010-10-08 21:44:36 -04:00
|
|
|
/**
|
|
|
|
* Basic hashmap that supports object keys.
|
|
|
|
*/
|
2010-09-18 11:11:44 -04:00
|
|
|
class HashMap
|
|
|
|
{
|
2023-08-02 13:29:14 +00:00
|
|
|
/**
|
|
|
|
* @var mixed[] $hashToValue
|
|
|
|
*/
|
2023-08-01 13:35:44 +00:00
|
|
|
private array $hashToValue = [];
|
2022-07-05 15:55:47 +02:00
|
|
|
|
2023-08-02 13:29:14 +00:00
|
|
|
/**
|
|
|
|
* @var mixed[] $hashToKey
|
|
|
|
*/
|
2023-08-01 13:35:44 +00:00
|
|
|
private array $hashToKey = [];
|
2010-09-18 11:11:44 -04:00
|
|
|
|
2023-08-01 12:56:37 +00:00
|
|
|
public function getValue(string|object $key): mixed
|
2010-09-18 11:11:44 -04:00
|
|
|
{
|
2010-09-28 08:12:06 -04:00
|
|
|
$hash = self::getHash($key);
|
2022-07-05 15:55:47 +02:00
|
|
|
|
2023-08-01 13:35:44 +00:00
|
|
|
return $this->hashToValue[$hash];
|
2010-09-18 11:11:44 -04:00
|
|
|
}
|
|
|
|
|
2023-08-01 12:56:37 +00:00
|
|
|
public function setValue(string|object $key, mixed $value): self
|
2010-09-18 11:11:44 -04:00
|
|
|
{
|
|
|
|
$hash = self::getHash($key);
|
2023-08-01 13:35:44 +00:00
|
|
|
$this->hashToKey[$hash] = $key;
|
|
|
|
$this->hashToValue[$hash] = $value;
|
2022-07-05 15:55:47 +02:00
|
|
|
|
2010-09-18 11:11:44 -04:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2023-08-02 13:29:14 +00:00
|
|
|
/**
|
|
|
|
* @return mixed[]
|
|
|
|
*/
|
2023-08-01 12:56:37 +00:00
|
|
|
public function getAllKeys(): array
|
2010-09-18 11:11:44 -04:00
|
|
|
{
|
2023-08-01 13:35:44 +00:00
|
|
|
return array_values($this->hashToKey);
|
2010-09-18 11:11:44 -04:00
|
|
|
}
|
|
|
|
|
2023-08-02 13:29:14 +00:00
|
|
|
/**
|
|
|
|
* @return mixed[]
|
|
|
|
*/
|
2023-08-01 12:56:37 +00:00
|
|
|
public function getAllValues(): array
|
2010-09-18 11:11:44 -04:00
|
|
|
{
|
2023-08-01 13:35:44 +00:00
|
|
|
return array_values($this->hashToValue);
|
2010-09-18 11:11:44 -04:00
|
|
|
}
|
|
|
|
|
2023-08-01 12:56:37 +00:00
|
|
|
public function count(): int
|
2016-05-24 14:10:39 +02:00
|
|
|
{
|
2023-08-01 13:35:44 +00:00
|
|
|
return count($this->hashToKey);
|
2010-09-18 11:11:44 -04:00
|
|
|
}
|
|
|
|
|
2023-08-01 13:35:44 +00:00
|
|
|
private static function getHash(string|object $key): string
|
2010-09-18 11:11:44 -04:00
|
|
|
{
|
2016-05-24 14:10:39 +02:00
|
|
|
if (is_object($key)) {
|
|
|
|
return spl_object_hash($key);
|
2010-09-18 11:11:44 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
return $key;
|
|
|
|
}
|
2022-07-05 15:55:47 +02:00
|
|
|
}
|