Download the PHP package alexeyshockov/colada without Composer
On this page you can find all versions of the php package alexeyshockov/colada. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download alexeyshockov/colada
More information about alexeyshockov/colada
Files in alexeyshockov/colada
Package colada
Short Description Collections framework for PHP
License MIT
Homepage http://github.com/alexeyshockov/colada
Informations about the package colada
Colada
Goal
Convenient and safe way to work with collections.
...And it's been (more or less) solved by some other libraries, like nikic/iter, doctrine/collections or even php-ds/php-ds. That's why the current version of the library contains just a few helpers for that libraries, to conveniently integrate them together.
Installation
Usage
The library's functions are split by namespaces, one namespace = specific function a dependency (in most cases).
\Colada\ds\{group_by}
Helpers from this namespace require php-ds/php-ds to be available.
group_by()
function prodices a two dimension array (\ArrayObject
or \Ds\Map
, depends on the group key type), from
an iterable based on a group function.
\Colada\GuzzleHttp\{coroutine_invoke, coroutine, time_sleep}
\Colada\React\{coroutine_invoke, coroutine}
Helpers from this namespace require guzzlehttp/promises or react/promise to be available.
This is the same concept applied to two most popular libs with async capabilities. If you are familiar with async/await in C# or node.js or coroutines in Go, this should be simple. Take a look at the script, written in callback-style and in coroutine-style:
\Colada\iter\opt\{get, head, last, find_one}
Helpers from this namespace require phpoption/phpoption to be available.
\Colada\iter\{to_kv_pairs, each_n_and_last, uasort, uksort}
Simple helpers for general iterable
types.
uasort()
and uksort()
are basically equivalents for the internal ones, but work for arbitrary iterable
type.
Contributing
Running Tests
To run all the tests, install the vendors (with Composer) and execute:
Public API
All classes or functions that are intended to be used by a user should be marked with @api
PHPDoc tag. Anything without this mark
are internal and should not be used by the end user (no guarantees that the interface will stay the same between
versions).
All versions of colada with dependencies
symfony/polyfill-php72 Version @stable
symfony/polyfill-php73 Version @stable