From 38cca46b4ff4fb01484b55834e460c926afe8727 Mon Sep 17 00:00:00 2001 From: Pol Dellaiera Date: Sun, 6 Feb 2022 11:03:27 +0100 Subject: [PATCH] refactor: Simplify and optimize `Transpose`. --- src/Operation/Transpose.php | 15 ++++----------- 1 file changed, 4 insertions(+), 11 deletions(-) diff --git a/src/Operation/Transpose.php b/src/Operation/Transpose.php index 90423d756..7b82e67fe 100644 --- a/src/Operation/Transpose.php +++ b/src/Operation/Transpose.php @@ -11,7 +11,7 @@ use Closure; use Generator; -use loophp\iterators\IterableIteratorAggregate; +use loophp\iterators\MultipleIterableAggregate; use MultipleIterator; /** @@ -19,12 +19,12 @@ * * @template TKey * @template T + * + * phpcs:disable Generic.Files.LineLength.TooLong */ final class Transpose extends AbstractOperation { /** - * @psalm-suppress ImpureMethodCall - using MultipleIterator as an internal tool which is not returned - * * @return Closure(iterable): Generator> */ public function __invoke(): Closure @@ -47,14 +47,7 @@ public function __invoke(): Closure /** @var Closure(iterable): Generator> $pipe */ $pipe = (new Pipe())()( - (new Reduce())()( - static function (MultipleIterator $acc, iterable $iterable): MultipleIterator { - $acc->attachIterator((new IterableIteratorAggregate($iterable))->getIterator()); - - return $acc; - } - )(new MultipleIterator(MultipleIterator::MIT_NEED_ANY)), - (new Flatten())()(1), + static fn (iterable $iterables): MultipleIterableAggregate => new MultipleIterableAggregate($iterables, MultipleIterator::MIT_NEED_ANY), (new Associate())()($callbackForKeys)($callbackForValues) );