updated docblocks
This commit is contained in:
parent
551742d8de
commit
e97a07273b
2 changed files with 22 additions and 0 deletions
|
@ -60,6 +60,9 @@ class Sort
|
||||||
* $data = [3, 1, 4, 1, 5, 9];
|
* $data = [3, 1, 4, 1, 5, 9];
|
||||||
* Sort::sort($data, fn ($a, $b) => $a % 2 <=> $b % 2, fn ($a, $b) => $a <=> $b);
|
* Sort::sort($data, fn ($a, $b) => $a % 2 <=> $b % 2, fn ($a, $b) => $a <=> $b);
|
||||||
* ```
|
* ```
|
||||||
|
*
|
||||||
|
* @param array &$data The array to sort, passed by reference.
|
||||||
|
* @param callable(mixed, mixed): int ...$comparisons An array of comparison callbacks that will be used to sort the array.
|
||||||
*/
|
*/
|
||||||
public static function sort(array &$data, callable ...$comparisons): void
|
public static function sort(array &$data, callable ...$comparisons): void
|
||||||
{
|
{
|
||||||
|
@ -75,6 +78,9 @@ class Sort
|
||||||
* $data = [3, 1, 4, 1, 5, 9];
|
* $data = [3, 1, 4, 1, 5, 9];
|
||||||
* Sort::sort($data, Sort::reverse(fn ($a, $b) => $a <=> $b));
|
* Sort::sort($data, Sort::reverse(fn ($a, $b) => $a <=> $b));
|
||||||
* ```
|
* ```
|
||||||
|
*
|
||||||
|
* @param callable(mixed, mixed): int $comparison The original comparison callback.
|
||||||
|
* @return callable(mixed, mixed): int A new comparison callback that will reverse the order of the original callback.
|
||||||
*/
|
*/
|
||||||
public static function reverse(callable $comparison): callable
|
public static function reverse(callable $comparison): callable
|
||||||
{
|
{
|
||||||
|
@ -94,6 +100,10 @@ class Sort
|
||||||
* $data = [...]; // array of objects with getNumber() method
|
* $data = [...]; // array of objects with getNumber() method
|
||||||
* Sort::sort($data, Sort::compareMethods('getNumber'));
|
* Sort::sort($data, Sort::compareMethods('getNumber'));
|
||||||
* ```
|
* ```
|
||||||
|
*
|
||||||
|
* @param string $method_name The name of the method to call on the objects.
|
||||||
|
* @param mixed ...$args Optional arguments to pass to the method.
|
||||||
|
* @return callable(object, object): int A comparison callback that will compare the results of calling the method on two objects.
|
||||||
*/
|
*/
|
||||||
public static function compareMethods(string $method_name, mixed ...$args): callable
|
public static function compareMethods(string $method_name, mixed ...$args): callable
|
||||||
{
|
{
|
||||||
|
@ -112,6 +122,9 @@ class Sort
|
||||||
* $data = [...]; // array of objects with itemName property
|
* $data = [...]; // array of objects with itemName property
|
||||||
* Sort::sort($data, Sort::compareProperties('itemName'));
|
* Sort::sort($data, Sort::compareProperties('itemName'));
|
||||||
* ```
|
* ```
|
||||||
|
*
|
||||||
|
* @param string $property_name The name of the property to compare.
|
||||||
|
* @return callable(object, object): int A comparison callback that will compare the values of the property on two objects.
|
||||||
*/
|
*/
|
||||||
public static function compareProperties(string $property_name): callable
|
public static function compareProperties(string $property_name): callable
|
||||||
{
|
{
|
||||||
|
@ -134,6 +147,9 @@ class Sort
|
||||||
* ];
|
* ];
|
||||||
* Sort::sort($data, Sort::compareArrayValues('name'));
|
* Sort::sort($data, Sort::compareArrayValues('name'));
|
||||||
* ```
|
* ```
|
||||||
|
*
|
||||||
|
* @param string $key The key to compare in the arrays.
|
||||||
|
* @return callable(array, array): int A comparison callback that will compare the values of the key in two arrays.
|
||||||
*/
|
*/
|
||||||
public static function compareArrayValues(string $key): callable
|
public static function compareArrayValues(string $key): callable
|
||||||
{
|
{
|
||||||
|
@ -152,6 +168,8 @@ class Sort
|
||||||
* $data = ['apple', 'banana', 'cherry', 'date', 'elderberry'];
|
* $data = ['apple', 'banana', 'cherry', 'date', 'elderberry'];
|
||||||
* Sort::sort($data, Sort::compareCallbackResults(strlen(...)));
|
* Sort::sort($data, Sort::compareCallbackResults(strlen(...)));
|
||||||
* ```
|
* ```
|
||||||
|
*
|
||||||
|
* @param callable(mixed): mixed $callback The callback to run on items to compare. Its output will be sorted normally using <=>.
|
||||||
*/
|
*/
|
||||||
public static function compareCallbackResults(callable $callback): callable
|
public static function compareCallbackResults(callable $callback): callable
|
||||||
{
|
{
|
||||||
|
|
|
@ -43,6 +43,8 @@ class Sorter
|
||||||
* Create a new Sorter object with the given list of sorting callbacks.
|
* Create a new Sorter object with the given list of sorting callbacks.
|
||||||
* The sorters will be called in order, and the array will be sorted based
|
* The sorters will be called in order, and the array will be sorted based
|
||||||
* on the first one to return a non-zero value.
|
* on the first one to return a non-zero value.
|
||||||
|
*
|
||||||
|
* @param callable(mixed, mixed): int ...$comparisons
|
||||||
*/
|
*/
|
||||||
public function __construct(callable ...$comparisons)
|
public function __construct(callable ...$comparisons)
|
||||||
{
|
{
|
||||||
|
@ -52,6 +54,8 @@ class Sorter
|
||||||
/**
|
/**
|
||||||
* Add one or more sorting callbacks to this sorter. The new callbacks will
|
* Add one or more sorting callbacks to this sorter. The new callbacks will
|
||||||
* be appended to the end of the existing list of sorters.
|
* be appended to the end of the existing list of sorters.
|
||||||
|
*
|
||||||
|
* @param callable(mixed, mixed): int ...$comparisons
|
||||||
*/
|
*/
|
||||||
public function addComparison(callable ...$comparisons): static
|
public function addComparison(callable ...$comparisons): static
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue