digitalrevolution / utils
A library for everyday use utility classes
Installs: 25 646
Dependents: 1
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 4
Open Issues: 1
Requires
- php: >=8.1
Requires (Dev)
- digitalrevolution/phpunit-file-coverage-inspection: ^v2.0.0
- mikey179/vfsstream: ^1.6.11
- nikic/php-parser: ^4.10
- phpmd/phpmd: ^2.13
- phpstan/extension-installer: ^1.3
- phpstan/phpstan: ^1.10
- phpstan/phpstan-phpunit: ^1.3
- phpstan/phpstan-strict-rules: ^1.5
- phpunit/phpunit: ^10.2
- roave/security-advisories: dev-latest
- squizlabs/php_codesniffer: ^3.7
- dev-master
- v1.21.0
- v1.20.0
- v1.19.0
- v1.18.0
- v1.17.0
- v1.16.0
- v1.15.0
- v1.14.0
- v1.13.0
- v1.12.0
- v1.11.0
- v1.10.0
- v1.9.0
- v1.8.0
- v1.7.1
- v1.7.0
- v1.6.0
- v1.5.2
- v1.5.1
- v1.5.0
- v1.4.0
- v1.3.0
- v1.2.1
- v1.2.0
- v1.1.0
- v1.0.0
- dev-Update-phpstan
- dev-Add-phpstan-check-for-unnecessary-assertions
- dev-renovate/major-phpstan-packages
- dev-renovate/phpunit-phpunit-11.x
- dev-renovate/nikic-php-parser-5.x
This package is auto-updated.
Last update: 2025-01-02 16:02:49 UTC
README
DR Utility Classes
A library with everyday use classes and methods:
Arrays
first
- Get the first element of an array, exception otherwise.firstOrNull
- Get the first element of an array, null otherwise.last
- Get the last element of an array, exception otherwise.lastOrNull
- Get the last element of an array, null otherwise.find
- Find the first element in an array that matches a predicate, exception otherwise.findOrNull
- Find the first element in an array that matches a predicate, null otherwise.flatten
- Recursively flattens an array returning an array with all the elements.contains
- Test if the given value is contained within items. SupportsEquatableInterface
.diff
- Get the difference between two arrays. SupportsComparableInterface
.equals
- Tests if two arrays have equal contents, ignoring order. SupportsComparableInterface
.explode
- Explode a string or null into an array, with exploding empty string to empty array.map
- Similar toarray_map
but with support foriterable
, and receive key as second argument in the callback.mapAssoc
- Map an array to a new array using a callback, preserving keys.reindex
- Reindex an array with new keys based on the result of the callback.groupBy
- Group items by the given return value of the callback.renameKey
- Rename thestring
key of an array element.remove
- Remove an element from an array based on the callback. SupportsEquatableInterface
.removeKey
- Remove an element from an array based on the key.removeKeys
- Remove multiple elements from an array based on the keys.removeTypes
- Filters an array by removing all values that match the provided types.removeNull
- Filters an array by removing all null values.search
- Find the key of an element in an array or false otherwise. SupportsEquatableInterface
.unique
- Remove duplicate values from an array. SupportsEquatableInterface
.wrap
- Wrap a value in an array, unless it is already an array.toJson
- Converts an array into a json string.fromJson
- Converts a json string into an array.
Assert
Fluent assertion methods, inspired by webmozart/assert
:
null
notNull
isArray
inArray
isCallable
resource
object
scalar
integer
numeric
float
string
classString
startsWith
notStartsWith
endsWith
notEndsWith
boolean
true
false
notFalse
nonEmptyArray
nonEmptyString
isInstanceOf
type
fileExists
file
directory
readable
writable
Example
$value = Assert::notNull($this->repository->find(123));
Stringify
::value(mixed $value): string
Easily convert any value to a string representation.
true > 'true' false > 'false' null > 'null' 123 > '123' 1.23 > '1.23' 'abc' > 'abc' '' > 'empty-string', [] > 'empty-array' [1, 2, 3] > 'array-list(3)' ['foo' => 'bar'] => 'keyed-array(1)' StringableObject => 'value (StringableObject)' stdClass => 'stdClass' resource => 'resource (stream)'
Installation
composer require digitalrevolution/utils
About us
At 123inkt (Part of Digital Revolution B.V.), every day more than 50 development professionals are working on improving our internal ERP and our several shops. Do you want to join us? We are looking for developers.