mirror of
https://github.com/danog/endtoend-test-psl.git
synced 2025-01-23 05:41:21 +01:00
[Dict] add unique_scalar() function to avoid performance penalty hit when using Dict\unique() on large scalar arrays (#168)
Co-authored-by: yivi <ivan@yivoff.com>
This commit is contained in:
parent
903aab0360
commit
dcb13b9586
@ -49,5 +49,6 @@
|
||||
- [take_while](./../../src/Psl/Dict/take_while.php#L26)
|
||||
- [unique](./../../src/Psl/Dict/unique.php#L17)
|
||||
- [unique_by](./../../src/Psl/Dict/unique_by.php#L23)
|
||||
- [unique_scalar](./../../src/Psl/Dict/unique_scalar.php#L21)
|
||||
|
||||
|
||||
|
38
src/Psl/Dict/unique_scalar.php
Normal file
38
src/Psl/Dict/unique_scalar.php
Normal file
@ -0,0 +1,38 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace Psl\Dict;
|
||||
|
||||
use function array_unique;
|
||||
use function is_array;
|
||||
|
||||
/**
|
||||
* Returns a new dict in which each value appears exactly once. Better performant than `Dict\unique()` when the values
|
||||
* are only scalars.
|
||||
*
|
||||
* @template Tk of array-key
|
||||
* @template Tv of scalar
|
||||
*
|
||||
* @param iterable<Tk, Tv> $iterable
|
||||
*
|
||||
* @return array<Tk, Tv>
|
||||
*/
|
||||
function unique_scalar(iterable $iterable): array
|
||||
{
|
||||
if (is_array($iterable)) {
|
||||
return array_unique($iterable);
|
||||
}
|
||||
|
||||
return unique_by(
|
||||
$iterable,
|
||||
/**
|
||||
* @param scalar $v
|
||||
*
|
||||
* @return scalar
|
||||
*
|
||||
* @pure
|
||||
*/
|
||||
static fn($v) => $v
|
||||
);
|
||||
}
|
@ -136,6 +136,7 @@ final class Loader
|
||||
'Psl\Dict\take_while',
|
||||
'Psl\Dict\unique',
|
||||
'Psl\Dict\unique_by',
|
||||
'Psl\Dict\unique_scalar',
|
||||
'Psl\Dict\diff',
|
||||
'Psl\Dict\diff_by_key',
|
||||
'Psl\Dict\intersect',
|
||||
|
46
tests/Psl/Dict/UniqueScalarTest.php
Normal file
46
tests/Psl/Dict/UniqueScalarTest.php
Normal file
@ -0,0 +1,46 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace Psl\Tests\Dict;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Psl\Collection;
|
||||
use Psl\Dict;
|
||||
use Psl\Iter;
|
||||
use Psl\Vec;
|
||||
|
||||
final class UniqueScalarTest extends TestCase
|
||||
{
|
||||
|
||||
public function testUniqueScalars(): void
|
||||
{
|
||||
$array = Vec\fill(10, 'foo');
|
||||
$array[] = 'bar';
|
||||
|
||||
$unique = Dict\unique_scalar($array);
|
||||
|
||||
static::assertCount(2, $unique);
|
||||
static::assertSame(['foo', 'bar'], Vec\values($unique));
|
||||
}
|
||||
|
||||
public function testUniqueIterator()
|
||||
{
|
||||
$array = Iter\Iterator::create(['foo', 'foo', 'bar', 'bar', 'baz']);
|
||||
|
||||
$unique = Dict\unique_scalar($array);
|
||||
|
||||
static::assertCount(3, $unique);
|
||||
static::assertSame(['foo', 'bar', 'baz'], Vec\values($unique));
|
||||
}
|
||||
|
||||
public function testUniqueIteratorAgggregate()
|
||||
{
|
||||
$array = Collection\Map::fromArray(['foo', 'foo', 'bar', 'bar', 'baz']);
|
||||
|
||||
$unique = Dict\unique_scalar($array);
|
||||
|
||||
static::assertCount(3, $unique);
|
||||
static::assertSame(['foo', 'bar', 'baz'], Vec\values($unique));
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user