diff options
author | Mario <mario@mariovavti.com> | 2023-11-25 17:12:28 +0100 |
---|---|---|
committer | Mario <mario@mariovavti.com> | 2023-11-25 17:12:28 +0100 |
commit | 0fd8e02a884a2b040dca62ab5d9674db5f6a070b (patch) | |
tree | 586ee43f32f6f14368c09026f21dcd3244ea24b6 /vendor/patrickschur/language-detection/src/LanguageDetection/LanguageResult.php | |
parent | 82e704ec5b107823c09f1387e9091adee53a4c2d (diff) | |
parent | 55c4bfb67009c598f25b1a8189604bfffa73dfbb (diff) | |
download | volse-hubzilla-8.8.tar.gz volse-hubzilla-8.8.tar.bz2 volse-hubzilla-8.8.zip |
Merge branch '8.8RC'8.8
Diffstat (limited to 'vendor/patrickschur/language-detection/src/LanguageDetection/LanguageResult.php')
-rw-r--r-- | vendor/patrickschur/language-detection/src/LanguageDetection/LanguageResult.php | 149 |
1 files changed, 149 insertions, 0 deletions
diff --git a/vendor/patrickschur/language-detection/src/LanguageDetection/LanguageResult.php b/vendor/patrickschur/language-detection/src/LanguageDetection/LanguageResult.php new file mode 100644 index 000000000..5b89ff44e --- /dev/null +++ b/vendor/patrickschur/language-detection/src/LanguageDetection/LanguageResult.php @@ -0,0 +1,149 @@ +<?php + +declare(strict_types = 1); + +namespace LanguageDetection; + +/** + * Class LanguageResult + * + * @copyright Patrick Schur + * @license https://opensource.org/licenses/mit-license.html MIT + * @author Patrick Schur <patrick_schur@outlook.de> + * @package LanguageDetection + */ +class LanguageResult implements \JsonSerializable, \IteratorAggregate, \ArrayAccess +{ + const THRESHOLD = .025; + + /** + * @var array + */ + private $result = []; + + /** + * LanguageResult constructor. + * @param array $result + */ + public function __construct(array $result = []) + { + $this->result = $result; + } + + /** + * @param mixed $offset + * @return bool + */ + public function offsetExists($offset): bool + { + return isset($this->result[$offset]); + } + + /** + * @param mixed $offset + * @return mixed|null + */ + public function offsetGet($offset): ?float + { + return $this->result[$offset] ?? null; + } + + /** + * @param mixed $offset + * @param mixed $value + * @return void + */ + public function offsetSet($offset, $value): void + { + if (null === $offset) { + $this->result[] = $value; + } else { + $this->result[$offset] = $value; + } + } + + /** + * @param mixed $offset + */ + public function offsetUnset($offset): void + { + unset($this->result[$offset]); + } + + /** + * @return array + */ + public function jsonSerialize(): array + { + return $this->result; + } + + /** + * @return string + */ + public function __toString(): string + { + return (string) \key($this->result); + } + + /** + * @param \string[] ...$whitelist + * @return LanguageResult + */ + public function whitelist(string ...$whitelist): LanguageResult + { + return new LanguageResult(\array_intersect_key($this->result, \array_flip($whitelist))); + } + + /** + * @param \string[] ...$blacklist + * @return LanguageResult + */ + public function blacklist(string ...$blacklist): LanguageResult + { + return new LanguageResult(\array_diff_key($this->result, \array_flip($blacklist))); + } + + /** + * @return array + */ + public function close(): array + { + return $this->result; + } + + /** + * @return LanguageResult + */ + public function bestResults(): LanguageResult + { + if (!\count($this->result)) + { + return new LanguageResult; + } + + $first = \array_values($this->result)[0]; + + return new LanguageResult(\array_filter($this->result, function ($value) use ($first) { + return ($first - $value) <= self::THRESHOLD ? true : false; + })); + } + + /** + * @return \ArrayIterator + */ + public function getIterator(): \ArrayIterator + { + return new \ArrayIterator($this->result); + } + + /** + * @param int $offset + * @param int|null $length + * @return LanguageResult + */ + public function limit(int $offset, int $length = null): LanguageResult + { + return new LanguageResult(\array_slice($this->result, $offset, $length)); + } +} |