Skip to content

Commit

Permalink
feat(collections): introduce Set, SetInterface, MutableSet, and…
Browse files Browse the repository at this point in the history
… `MutableSetInterface`

Signed-off-by: azjezz <azjezz@protonmail.com>
  • Loading branch information
azjezz committed Jul 2, 2024
1 parent cb7bd70 commit f522665
Show file tree
Hide file tree
Showing 25 changed files with 2,489 additions and 268 deletions.
6 changes: 5 additions & 1 deletion docs/component/collection.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,18 +16,22 @@
- [CollectionInterface](./../../src/Psl/Collection/CollectionInterface.php#L23)
- [IndexAccessInterface](./../../src/Psl/Collection/IndexAccessInterface.php#L13)
- [MapInterface](./../../src/Psl/Collection/MapInterface.php#L15)
- [MutableAccessibleCollectionInterface](./../../src/Psl/Collection/MutableAccessibleCollectionInterface.php#L22)
- [MutableAccessibleCollectionInterface](./../../src/Psl/Collection/MutableAccessibleCollectionInterface.php#L23)
- [MutableCollectionInterface](./../../src/Psl/Collection/MutableCollectionInterface.php#L22)
- [MutableIndexAccessInterface](./../../src/Psl/Collection/MutableIndexAccessInterface.php#L16)
- [MutableMapInterface](./../../src/Psl/Collection/MutableMapInterface.php#L16)
- [MutableSetInterface](./../../src/Psl/Collection/MutableSetInterface.php#L15)
- [MutableVectorInterface](./../../src/Psl/Collection/MutableVectorInterface.php#L15)
- [SetInterface](./../../src/Psl/Collection/SetInterface.php#L14)
- [VectorInterface](./../../src/Psl/Collection/VectorInterface.php#L14)

#### `Classes`

- [Map](./../../src/Psl/Collection/Map.php#L25)
- [MutableMap](./../../src/Psl/Collection/MutableMap.php#L25)
- [MutableSet](./../../src/Psl/Collection/MutableSet.php#L23)
- [MutableVector](./../../src/Psl/Collection/MutableVector.php#L23)
- [Set](./../../src/Psl/Collection/Set.php#L23)
- [Vector](./../../src/Psl/Collection/Vector.php#L22)


47 changes: 2 additions & 45 deletions src/Psl/Collection/AccessibleCollectionInterface.php
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ public function keys(): AccessibleCollectionInterface;
* that meet a supplied condition.
*
* Only values that meet a certain criteria are affected by a call to
* `filter()`, while all values are affected by a call to `map()`.
* `filter()`.
*
* The keys associated with the current `AccessibleCollectionInterface` remain unchanged in the
* returned `AccessibleCollectionInterface`.
Expand All @@ -61,8 +61,7 @@ public function filter(Closure $fn): AccessibleCollectionInterface;
* that meet a supplied condition applied to its keys and values.
*
* Only keys and values that meet a certain criteria are affected by a call
* to `filterWithKey()`, while all values are affected by a call to
* `mapWithKey()`.
* to `filterWithKey()`.
*
* The keys associated with the current `AccessibleCollectionInterface` remain unchanged in the
* returned `AccessibleCollectionInterface`; the keys will be used in the filtering process only.
Expand All @@ -76,48 +75,6 @@ public function filter(Closure $fn): AccessibleCollectionInterface;
*/
public function filterWithKey(Closure $fn): AccessibleCollectionInterface;

/**
* Returns a `AccessibleCollectionInterface` after an operation has been applied to each value
* in the current `AccessibleCollectionInterface`.
*
* Every value in the current Map is affected by a call to `map()`, unlike
* `filter()` where only values that meet a certain criteria are affected.
*
* The keys will remain unchanged from the current `AccessibleCollectionInterface` to the
* returned `AccessibleCollectionInterface`.
*
* @template Tu
*
* @param (Closure(Tv): Tu) $fn The callback containing the operation to apply to the current
* `AccessibleCollectionInterface` values.
*
* @return AccessibleCollectionInterface<Tk, Tu> A `AccessibleCollectionInterface` containing key/value
* pairs after a user-specified operation is applied.
*/
public function map(Closure $fn): AccessibleCollectionInterface;

/**
* Returns a `AccessibleCollectionInterface` after an operation has been applied to each key and
* value in the current `AccessibleCollectionInterface`.
*
* Every key and value in the current `AccessibleCollectionInterface` is affected by a call to
* `mapWithKey()`, unlike `filterWithKey()` where only values that meet a
* certain criteria are affected.
*
* The keys will remain unchanged from this `AccessibleCollectionInterface` to the returned
* `AccessibleCollectionInterface`. The keys are only used to help in the mapping operation.
*
* @template Tu
*
* @param (Closure(Tk, Tv): Tu) $fn The callback containing the operation to apply to the current
* `AccessibleCollectionInterface` keys and values.
*
* @return AccessibleCollectionInterface<Tk, Tu> A `AccessibleCollectionInterface` containing the values
* after a user-specified operation on the current
* `AccessibleCollectionInterface`'s keys and values is applied.
*/
public function mapWithKey(Closure $fn): AccessibleCollectionInterface;

/**
* Returns the first value in the current `AccessibleCollectionInterface`.
*
Expand Down
47 changes: 2 additions & 45 deletions src/Psl/Collection/CollectionInterface.php
Original file line number Diff line number Diff line change
Expand Up @@ -60,8 +60,7 @@ public function jsonSerialize(): array;
* Returns a `CollectionInterface` containing the values of the current `CollectionInterface`
* that meet a supplied condition.
*
* Only values that meet a certain criteria are affected by a call to
* `filter()`, while all values are affected by a call to `map()`.
* Only values that meet a certain criteria are affected by a call to `filter()`.
*
* The keys associated with the current `CollectionInterface` remain unchanged in the
* returned `CollectionInterface`.
Expand All @@ -79,8 +78,7 @@ public function filter(Closure $fn): CollectionInterface;
* that meet a supplied condition applied to its keys and values.
*
* Only keys and values that meet a certain criteria are affected by a call
* to `filterWithKey()`, while all values are affected by a call to
* `mapWithKey()`.
* to `filterWithKey()`.
*
* The keys associated with the current `CollectionInterface` remain unchanged in the
* returned `CollectionInterface`; the keys will be used in the filtering process only.
Expand All @@ -94,47 +92,6 @@ public function filter(Closure $fn): CollectionInterface;
*/
public function filterWithKey(Closure $fn): CollectionInterface;

/**
* Returns a `CollectionInterface` after an operation has been applied to each value
* in the current `CollectionInterface`.
*
* Every value in the current Map is affected by a call to `map()`, unlike
* `filter()` where only values that meet a certain criteria are affected.
*
* The keys will remain unchanged from the current `CollectionInterface` to the
* returned `CollectionInterface`.
*
* @template Tu
*
* @param (Closure(Tv): Tu) $fn The callback containing the operation to apply to the current
* `CollectionInterface` values.
*
* @return CollectionInterface<Tk, Tu> A `CollectionInterface` containing key/value pairs after
* a user-specified operation is applied.
*/
public function map(Closure $fn): CollectionInterface;

/**
* Returns a `CollectionInterface` after an operation has been applied to each key and
* value in the current `CollectionInterface`.
*
* Every key and value in the current `CollectionInterface` is affected by a call to
* `mapWithKey()`, unlike `filterWithKey()` where only values that meet a
* certain criteria are affected.
*
* The keys will remain unchanged from this `CollectionInterface` to the returned
* `CollectionInterface`. The keys are only used to help in the mapping operation.
*
* @template Tu
*
* @param (Closure(Tk, Tv): Tu) $fn The callback containing the operation to apply to the current
* `CollectionInterface` keys and values.
*
* @return CollectionInterface<Tk, Tu> A `CollectionInterface` containing the values after a user-specified
* operation on the current `CollectionInterface`'s keys and values is applied.
*/
public function mapWithKey(Closure $fn): CollectionInterface;

/**
* Returns a `CollectionInterface` where each element is a `array{0: Tv, 1: Tu}` that combines the
* element of the current `CollectionInterface` and the provided elements array.
Expand Down
2 changes: 1 addition & 1 deletion src/Psl/Collection/Exception/OutOfBoundsException.php
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ final class OutOfBoundsException extends Exception\OutOfBoundsException implemen
/**
* @psalm-mutation-free
*/
public static function for(string|int $offset): OutOfBoundsException
public static function for(int|string $offset): OutOfBoundsException
{
return new self(Str\format('Key (%s) was out-of-bounds.', $offset));
}
Expand Down
11 changes: 11 additions & 0 deletions src/Psl/Collection/Exception/RuntimeException.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
<?php

declare(strict_types=1);

namespace Psl\Collection\Exception;

use Psl\Exception;

final class RuntimeException extends Exception\RuntimeException implements ExceptionInterface
{
}
4 changes: 2 additions & 2 deletions src/Psl/Collection/IndexAccessInterface.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ interface IndexAccessInterface
*
* @psalm-mutation-free
*/
public function at(string|int $k): mixed;
public function at(int|string $k): mixed;

/**
* Determines if the specified key is in the current collection.
Expand All @@ -43,5 +43,5 @@ public function contains(int|string $k): bool;
*
* @psalm-mutation-free
*/
public function get(string|int $k): mixed;
public function get(int|string $k): mixed;
}
4 changes: 2 additions & 2 deletions src/Psl/Collection/Map.php
Original file line number Diff line number Diff line change
Expand Up @@ -219,7 +219,7 @@ public function jsonSerialize(): array
*
* @psalm-mutation-free
*/
public function at(string|int $k): mixed
public function at(int|string $k): mixed
{
if (!array_key_exists($k, $this->elements)) {
throw Exception\OutOfBoundsException::for($k);
Expand Down Expand Up @@ -249,7 +249,7 @@ public function contains(int|string $k): bool
*
* @psalm-mutation-free
*/
public function get(string|int $k): mixed
public function get(int|string $k): mixed
{
return $this->elements[$k] ?? null;
}
Expand Down
139 changes: 57 additions & 82 deletions src/Psl/Collection/MutableAccessibleCollectionInterface.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,11 @@

namespace Psl\Collection;

use ArrayAccess;
use Closure;

/**
* The base interface implemented for a collection type that you are able set and remove its values.
* keys.
* The base interface implemented for a collection type that you are able remove its values.
*
* Every concrete mutable class indirectly implements this interface.
*
Expand All @@ -18,9 +18,11 @@
* @extends AccessibleCollectionInterface<Tk, Tv>
* @extends MutableCollectionInterface<Tk, Tv>
* @extends MutableIndexAccessInterface<Tk, Tv>
* @extends ArrayAccess<Tk, Tv>
*/
interface MutableAccessibleCollectionInterface extends
AccessibleCollectionInterface,
ArrayAccess,
MutableCollectionInterface,
MutableIndexAccessInterface
{
Expand Down Expand Up @@ -49,7 +51,7 @@ public function keys(): MutableAccessibleCollectionInterface;
* `MutableAccessibleCollectionInterface` that meet a supplied condition.
*
* Only values that meet a certain criteria are affected by a call to
* `filter()`, while all values are affected by a call to `map()`.
* `filter()`.
*
* The keys associated with the current `MutableAccessibleCollectionInterface` remain unchanged in the
* returned `MutableAccessibleCollectionInterface`.
Expand All @@ -67,8 +69,7 @@ public function filter(Closure $fn): MutableAccessibleCollectionInterface;
* `MutableAccessibleCollectionInterface` that meet a supplied condition applied to its keys and values.
*
* Only keys and values that meet a certain criteria are affected by a call
* to `filterWithKey()`, while all values are affected by a call to
* `mapWithKey()`.
* to `filterWithKey()`.
*
* The keys associated with the current `MutableAccessibleCollectionInterface` remain unchanged in the
* returned `MutableAccessibleCollectionInterface`; the keys will be used in the filtering process only.
Expand All @@ -83,83 +84,6 @@ public function filter(Closure $fn): MutableAccessibleCollectionInterface;
*/
public function filterWithKey(Closure $fn): MutableAccessibleCollectionInterface;

/**
* Returns a `MutableAccessibleCollectionInterface` after an operation has been applied to each value
* in the current `MutableAccessibleCollectionInterface`.
*
* Every value in the current Map is affected by a call to `map()`, unlike
* `filter()` where only values that meet a certain criteria are affected.
*
* The keys will remain unchanged from the current `MutableAccessibleCollectionInterface` to the
* returned `MutableAccessibleCollectionInterface`.
*
* @template Tu
*
* @param (Closure(Tv): Tu) $fn The callback containing the operation to apply to the current
* `MutableAccessibleCollectionInterface` values.
*
* @return MutableAccessibleCollectionInterface<Tk, Tu> A `MutableAccessibleCollectionInterface` containing
* key/value pairs after a user-specified operation is applied.
*/
public function map(Closure $fn): MutableAccessibleCollectionInterface;

/**
* Returns a `MutableAccessibleCollectionInterface` after an operation has been applied to each key and
* value in the current `MutableAccessibleCollectionInterface`.
*
* Every key and value in the current `MutableAccessibleCollectionInterface` is affected by a call to
* `mapWithKey()`, unlike `filterWithKey()` where only values that meet a
* certain criteria are affected.
*
* The keys will remain unchanged from this `MutableAccessibleCollectionInterface` to the returned
* `MutableAccessibleCollectionInterface`. The keys are only used to help in the mapping operation.
*
* @template Tu
*
* @param (Closure(Tk, Tv): Tu) $fn The callback containing the operation to apply to the current
* `MutableAccessibleCollectionInterface` keys and values.
*
* @return MutableAccessibleCollectionInterface<Tk, Tu> A `MutableAccessibleCollectionInterface` containing
* the values after a user-specified operation on the current
* `MutableAccessibleCollectionInterface`'s keys and values is
* applied.
*/
public function mapWithKey(Closure $fn): MutableAccessibleCollectionInterface;

/**
* Stores a value into the current collection with the specified key,
* overwriting the previous value associated with the key.
*
* If the key is not present, an exception is thrown. If you want to add
* a value even if a key is not present, use `add()`.
*
* It returns the current collection, meaning changes made to the current
* collection will be reflected in the returned collection.
*
* @param Tk $k The key to which we will set the value.
* @param Tv $v The value to set.
*
* @return MutableAccessibleCollectionInterface<Tk, Tv> Returns itself.
*/
public function set(int|string $k, mixed $v): MutableAccessibleCollectionInterface;

/**
* For every element in the provided elements, stores a value into the
* current collection associated with each key, overwriting the previous value
* associated with the key.
*
* If the key is not present, an exception is thrown. If you want to add
* a value even if a key is not present, use `addAll()`.
*
* It the current collection, meaning changes made to the current collection
* will be reflected in the returned collection.
*
* @param array<Tk, Tv> $elements The elements with the new values to set.
*
* @return MutableAccessibleCollectionInterface<Tk, Tv> Returns itself.
*/
public function setAll(array $elements): MutableAccessibleCollectionInterface;

/**
* Removes the specified key (and associated value) from the current
* collection.
Expand Down Expand Up @@ -315,4 +239,55 @@ public function slice(int $start, ?int $length = null): MutableAccessibleCollect
* @psalm-mutation-free
*/
public function chunk(int $size): MutableAccessibleCollectionInterface;

/**
* Determines if the specified offset exists in the current collection.
*
* @param mixed $offset An offset to check for.
*
* @throws Exception\RuntimeException If the offset type is not valid.
*
* @return bool Returns true if the specified offset exists, false otherwise.
*
* @psalm-assert-if-true Tk $offset
*
* @psalm-mutation-free
*/
function offsetExists(mixed $offset): bool;

/**
* Returns the value at the specified offset.
*
* @param mixed $offset The offset to retrieve.
*
* @throws Exception\RuntimeException If the offset type is not valid.
*
* @return Tv|null The value at the specified offset, null if the offset does not exist.
*
* @psalm-mutation-free
*/
function offsetGet(mixed $offset): mixed;

/**
* Sets the value at the specified offset.
*
* @param mixed $offset The offset to assign the value to.
* @param Tv $value The value to set.
*
* @psalm-external-mutation-free
*
* @throws Exception\RuntimeException If the offset type is not valid.
*/
function offsetSet(mixed $offset, mixed $value): void;

/**
* Unsets the value at the specified offset.
*
* @param mixed $offset The offset to unset.
*
* @psalm-external-mutation-free
*
* @throws Exception\RuntimeException If the offset type is not valid.
*/
function offsetUnset(mixed $offset): void;
}
Loading

0 comments on commit f522665

Please sign in to comment.