Skip to content

Commit

Permalink
Iterables: $else [WIP]
Browse files Browse the repository at this point in the history
  • Loading branch information
dg committed Nov 30, 2023
1 parent 8bdea51 commit cf1f274
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 8 deletions.
16 changes: 8 additions & 8 deletions src/Utils/Iterables.php
Original file line number Diff line number Diff line change
Expand Up @@ -48,38 +48,38 @@ public static function containsKey(iterable $iterable, mixed $key): bool


/**
* Returns the first item (matching the specified predicate if given) or null if there is no such item.
* The callback has the signature `function ($value, $key, $iterable): bool`.
* Returns the first item (matching the specified predicate if given). If there is no such item, it returns result of invoking $else or null.
* The $predicate has the signature `function ($value, $key, $iterable): bool`.
* @template T
* @param iterable<T> $iterable
* @return ?T
*/
public static function first(iterable $iterable, ?callable $predicate = null): mixed
public static function first(iterable $iterable, ?callable $predicate = null, ?callable $else = null): mixed
{
foreach ($iterable as $k => $v) {
if (!$predicate || $predicate($v, $k, $iterable)) {
return $v;
}
}
return null;
return $else ? $else() : null;
}


/**
* Returns the key of first item (matching the specified predicate if given) or null if there is no such item.
* The callback has the signature `function ($value, $key, $iterable): bool`.
* Returns the key of first item (matching the specified predicate if given). If there is no such item, it returns result of invoking $else or null.
* The $predicate has the signature `function ($value, $key, $iterable): bool`.
* @template T
* @param iterable<T, mixed> $iterable
* @return ?T
*/
public static function firstKey(iterable $iterable, ?callable $predicate = null): mixed
public static function firstKey(iterable $iterable, ?callable $predicate = null, ?callable $else = null): mixed
{
foreach ($iterable as $k => $v) {
if (!$predicate || $predicate($v, $k, $iterable)) {
return $k;
}
}
return null;
return $else ? $else() : null;
}


Expand Down
4 changes: 4 additions & 0 deletions tests/Utils/Iterables.first().phpt
Original file line number Diff line number Diff line change
Expand Up @@ -37,3 +37,7 @@ test('with predicate', function () {
test('predicate arguments', function () {
Iterables::first([2 => 'x'], fn() => Assert::same(['x', 2, [2 => 'x']], func_get_args()));
});

test('else', function () {
Assert::same(123, Iterables::first(new ArrayIterator([]), else: fn() => 123));
});
4 changes: 4 additions & 0 deletions tests/Utils/Iterables.firstKey().phpt
Original file line number Diff line number Diff line change
Expand Up @@ -37,3 +37,7 @@ test('with predicate', function () {
test('predicate arguments', function () {
Iterables::firstKey([2 => 'x'], fn() => Assert::same(['x', 2, [2 => 'x']], func_get_args()));
});

test('else', function () {
Assert::same(123, Iterables::firstKey(new ArrayIterator([]), else: fn() => 123));
});

0 comments on commit cf1f274

Please sign in to comment.