snicco / str-arr
A standalone implementation of Laravel's Str and Arr classes.
Installs: 21 740
Dependents: 10
Suggesters: 0
Security: 0
Stars: 4
Watchers: 1
Forks: 0
pkg:composer/snicco/str-arr
Requires
- php: ^7.4|^8.0
- ext-mbstring: *
Requires (Dev)
- phpunit/phpunit: ^9.5.13
Conflicts
- snicco/better-wp-api: <2.0.0-beta.9
- snicco/better-wp-cache: <2.0.0-beta.9
- snicco/better-wp-cache-bundle: <2.0.0-beta.9
- snicco/better-wp-cli: <2.0.0-beta.9
- snicco/better-wp-cli-testing: <2.0.0-beta.9
- snicco/better-wp-hooks: <2.0.0-beta.9
- snicco/better-wp-hooks-bundle: <2.0.0-beta.9
- snicco/better-wp-mail: <2.0.0-beta.9
- snicco/better-wp-mail-bundle: <2.0.0-beta.9
- snicco/better-wp-mail-testing: <2.0.0-beta.9
- snicco/better-wpdb: <2.0.0-beta.9
- snicco/better-wpdb-bundle: <2.0.0-beta.9
- snicco/blade-bridge: <2.0.0-beta.9
- snicco/blade-bundle: <2.0.0-beta.9
- snicco/content-negotiation-middleware: <2.0.0-beta.9
- snicco/debug-bundle: <2.0.0-beta.9
- snicco/default-headers-middleware: <2.0.0-beta.9
- snicco/eloquent: <2.0.0-beta.9
- snicco/encryption-bundle: <2.0.0-beta.9
- snicco/event-dispatcher: <2.0.0-beta.9
- snicco/event-dispatcher-testing: <2.0.0-beta.9
- snicco/guests-only-middleware: <1.0.0
- snicco/http-routing: <2.0.0-beta.9
- snicco/http-routing-bundle: <2.0.0-beta.9
- snicco/http-routing-testing: <2.0.0-beta.9
- snicco/https-only-middleware: <2.0.0-beta.9
- snicco/illuminate-container-bridge: <2.0.0-beta.9
- snicco/kernel: <2.0.0-beta.9
- snicco/kernel-testing: <2.0.0-beta.9
- snicco/method-override-middleware: <2.0.0-beta.9
- snicco/minimal-logger: <2.0.0-beta.9
- snicco/must-match-route-middleware: <2.0.0-beta.9
- snicco/no-robots-middleware: <2.0.0-beta.9
- snicco/open-redirect-protection-middleware: <2.0.0-beta.9
- snicco/payload-middleware: <2.0.0-beta.9
- snicco/pimple-bridge: <2.0.0-beta.9
- snicco/psr7-error-handler: <2.0.0-beta.9
- snicco/redirect-middleware: <2.0.0-beta.9
- snicco/session: <2.0.0-beta.9
- snicco/session-bundle: <2.0.0-beta.9
- snicco/session-psr16-bridge: <2.0.0-beta.9
- snicco/session-testing: <2.0.0-beta.9
- snicco/session-wp-bridge: <2.0.0-beta.9
- snicco/share-cookies-middleware: <2.0.0-beta.9
- snicco/signed-url: <2.0.0-beta.9
- snicco/signed-url-psr15-bridge: <2.0.0-beta.9
- snicco/signed-url-psr16-bridge: <2.0.0-beta.9
- snicco/signed-url-testing: <2.0.0-beta.9
- snicco/signed-url-wp-bridge: <2.0.0-beta.9
- snicco/templating: <2.0.0-beta.9
- snicco/templating-bundle: <2.0.0-beta.9
- snicco/testable-clock: <2.0.0-beta.9
- snicco/testing-bundle: <2.0.0-beta.9
- snicco/trailing-slash-middleware: <2.0.0-beta.9
- snicco/wp-auth-only-middleware: <2.0.0-beta.9
- snicco/wp-capability-middleware: <2.0.0-beta.9
- snicco/wp-capapility-middleware: <1.0.0
- snicco/wp-guests-only-middleware: <2.0.0-beta.9
- snicco/wp-nonce-middleware: <2.0.0-beta.9
- dev-master
- v2.0.0-beta.9
- v2.0.0-beta.8
- v2.0.0-beta.7
- v2.0.0-beta.6
- v2.0.0-beta.5
- v2.0.0-beta.4
- v2.0.0-beta.3
- v2.0.0-beta.2
- v2.0.0-beta.1
- v1.10.1
- v1.10.0
- v1.9.1
- v1.9.0
- v1.8.1
- v1.8.0
- v1.7.0
- v1.6.2
- v1.6.1
- v1.6.0
- v1.5.0
- v1.4.2
- v1.4.1
- v1.4.0
- v1.3.0
- v1.2.1
- v1.2.0
- v1.1.3
- v1.1.2
- v1.1.1
- v1.1.0
- v1.0.2
- v1.0.1
- v1.0.0
- dev-beta
This package is auto-updated.
Last update: 2025-10-07 17:05:39 UTC
README
This package contains a subset of the illuminate/support Str and Arr
classes.
Laravel's string and array helpers are very handy utility classes
but pulling in the entire illuminate/support is not an option
when you are writing a framework-agnostic package.
The following modifications have been made:
Str:
- full multibyte support for all methods
- strict-typehints
Stris a final class- all hidden
illuminate/*dependencies are removed - full support for
@psalm.
Arr:
- strict-typehints
Arris a final class- all hidden
illuminate/*dependencies are removed Collectionreferences are replaces withArrayAccessorArrayObjectwhere applicable- full support for
@psalmand@templateannotations.
Installation
composer require snicco/str-arr
Usage
This package is pretty much self-documenting.
Check the source (Str, Arr) and tests (Str
, Arr)
Public API of Str:
use Snicco\Component\StrArr\Str; $subject = 'snicco.io'; Str::contains($subject, '.io') // true Str::containsAll($subject, ['.io', '.com']) // false Str::containsAny($subject, ['.io', '.com']) // true Str::studly('snicco str-arr'); // Snicco StrArr Str::ucfirst($subject); // Snicco.io Str::startsWith($subject, 'snicco') // true Str::endsWith($subject, '.io') // true Str::doesNotEndWith($subject, '.io') // false Str::afterFirst($subject, 'c') // co.io Str::afterLast($subject, 'c') // o.io Str::betweenFirst($subject, 'c', 'o') // o Str::betweenLast($subject, 'c', 'o') // co.io Str::beforeFirst($subject, 'o') // snicc Str::beforeLast($subject, 'o') // snicco.i Str::substr($subject, -3) // .io // This accepts any regex pattern. * will be replaced with ".*" Str::is($subject, 'snicco.*') // true Str::replaceFirst($subject, 'c', 'k') // snikco.io Str::replaceAll($subject, 'c', 'k') // snikko.io Str::pregReplace($subject, 'c', '/\.\w{2}/', '.de') // snicco.de
Public API of Arr:
use Snicco\Component\StrArr\Arr;use Snicco\Component\StrArr\Str; $array = [ 'foo' => 'bar' 'baz' => 'biz' 'boom' => [ 'bang' => 'pow' ] ] Arr::only($array, ['foo']) // ['foo'=>'bar'] // Returns the first array element Arr::first($array) // bar // Returns the first element matching the condition Arr::first( $array, fn(string $value, string $key) => Str::startsWith($key, 'f') ); // bar // With a default value Arr::first($array, fn($value) => is_int($value), 'default') // default Arr::random($array, 1) // returns one random value. Arr::toArray('foo') // ['foo'] Arr::toArray([]) // [] Arr::toArray(['foo']) // ['foo'] // Checks if all keys are strings Arr::isAssoc($array) // true Arr::isList($array) // false Arr::isList(['foo', 'bar']) // true Arr::get($array, 'foo') // bar Arr::get($array, 'bogus') // null Arr::get($array, 'bogus', 'default') // default Arr::get($array, 'boom.bang') // pow // passed by reference here Arr::set($array, 'boom.bang', 'POW'); Arr::has($array, 'foo') // true Arr::has($array, 'bogus') // false Arr::has($array, 'boom.bang') // true Arr::hasAll(['foo', 'bogus']) // false Arr::hasAny(['foo', 'bogus']) // true // Checks if the passed value is either array or ArrayAccess Arr::accessible($array) // true Arr::mergeRecursive($array, ['boom' => ['bang' => 'POW', 'new' => 'NEW']]) // [ 'foo' => 'bar' // 'baz' => 'biz' // 'boom' => [ // 'bang' => 'POW', // 'new => 'NEW' // ] // ] Arr::keyExists($array, 'foo') // true Arr::flatten($array) // ['bar', 'biz', 'pow'] Arr::except($array, ['foo', 'baz']) // [ // 'boom' => [ // 'bang' => 'POW', // 'new => 'NEW' // ] // ] // Passed by reference here Arr::remove($array, 'boom.bang'); // [ 'foo' => 'bar' // 'baz' => 'biz' // 'boom' => [] // ]
Contributing
This repository is a read-only split of the development repo of the Snicco project.
This is how you can contribute.
Reporting issues and sending pull requests
Please report issues in the Snicco monorepo.
Security
If you discover a security vulnerability, please follow our disclosure procedure.