petrobolos / fixed-array-functions
Laravel helper methods for working with high performance SPL fixed arrays.
Fund package maintenance!
Ko Fi
Installs: 58
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 2
pkg:composer/petrobolos/fixed-array-functions
Requires
- php: ^8.3
- illuminate/contracts: ^11.0|^12.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- larastan/larastan: ^2.9|^3.0
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.1.1
- orchestra/testbench: ^10.1.0
- pestphp/pest: ^3.0
- pestphp/pest-plugin-arch: ^3.0
- pestphp/pest-plugin-laravel: ^3.0
- phpstan/extension-installer: ^1.3
- phpstan/phpstan-deprecation-rules: ^1.1|^2.0
- phpstan/phpstan-phpunit: ^1.3|^2.0
- spatie/laravel-ray: ^1.35
README
SplFixedArrays are an implementation of a traditional, bounded array in the PHP standard library.
While they require manual resizing, they're significantly faster than regular arrays or collections when working with large sets of data.
Requirements
Currently, requires PHP 8.3 or above, and Laravel 11+.
Installation
You can install the package via Composer:
composer require petrobolos/fixed-array-functions
Fluent interface
FixedArray is best used with its fluent interface. If you're familiar with Illuminate collections, you'll feel right at
home. Provide it an SplFixedArray to get started, or a standard array or collection that will be automatically
converted. If you provide any other kind of data, including null
, it will be inserted into a new SplFixedArray.
use Petrobolos\FixedArray\FixedArrayable; // You can start by either instantiating a new instance of FixedArrayable, or by calling its helper method: // The array provided will be converted internally into an SplFixedArray. $array = new FixedArrayable([1, 2, 3]); // You can also use the helper function to do the same thing! $array = fixedArray([1, 2, 3]); // Lastly, you can use specific methods to begin building your interface logic: // The same will happen with this collection. $array = FixedArrayable::fromCollection(collect([1, 2, 3]); // From here, you can chain different methods, just like you would a collection. $result = $array ->addFrom([4, 5, 6]) ->resize(20) ->filter(fn ($value) => $value % 2 === 0)) ->map(fn ($value) => $value * 2)) ->get(); // The result will be a SplFixedArray containing [2, 4, 6] but still with 20 indices.
Static methods
You aren't forced to use the fluent interface and can access methods directly by calling them. This is useful if you only need to do one or two operations on a fixed array.
use Petrobolos\FixedArray; // Create a fixed array using the create method. $arr = FixedArray::create(); // Easily push or pop items to and from arrays without worrying about indices. FixedArray::push('apple', $arr); // Easily and efficiently merge fixed arrays, regular arrays, and even Illuminate collections. $everything = FixedArray::merge( $arr, ['a', 'regular', 'array'], collect(['and', 'an', 'illuminate', 'collection']), );
Full list of working methods
Method | Description | Example |
---|---|---|
add | Alias for push. | FixedArray::add('bacon', $arr) |
addFrom | Add an array or collection of items to an array. | FixedArray::addFrom([1, 2, 3], $arr) |
contains | Checks whether an item exists in a given array. | FixedArray::contains('needle', $haystack) |
count | Returns the number of items in a given array. | FixedArray::count($array) |
create | Creates a new fixed array. | FixedArray::create(10) |
each | Apply a callback to each item in the array without modifying the original. | FixedArray::each($array, fn () => var_dump($value)) |
filter | Applies a filter to a given fixed array. | FixedArray::filter($array, fn ($value) => $value % 2 === 0) |
first | Returns the first element of the array. | FixedArray::first($array) |
fromArray | Creates a new fixed array from a standard array. | FixedArray::fromArray([1, 2, 3]) |
fromCollection | Creates a new fixed array from an Illuminate collection. | FixedArray::fromCollection(collect([1, 2, 3]) |
getSize | Alias for count. | FixedArray::getSize($array) |
isFixedArray | Returns whether a given item is a fixed array. | FixedArray::isFixedArray($potentialArray) |
last | Returns the last element in an array. | FixedArray::last($array) |
map | Applies a callback to each item in the array and returns it. | FixedArray::map($array, fn ($value) => (string) $value) |
merge | Merges given arrays, fixed arrays, or collections into a given fixed array. | FixedArray::merge($array, $array2, $array3) |
nullify | Overwrite all elements in an array with null . |
FixedArray::nullify($array) |
offsetExists | Returns whether a given array offset exists. | FixedArray::offsetExists(3, $haystack) |
offsetGet | Retrieves the value at a given array offset. | FixedArray::offsetGet(3, $haystack) |
offsetNull | Replaces the value at a given array offset with null . |
FixedArray::offsetNull(3, $haystack) |
offsetSet | Replaces the value at a given array offset with a provided value. | FixedArray::offsetSet(3, $value, $haystack) |
pop | Pops the latest value from the array. | FixedArray::pop($array) |
push | Pushes a given value to the first available space on the array. | FixedArray::push($value, $array) |
resize | Alias for setSize. | FixedArray::resize(10, $array) |
second | Returns the second value from the array. | FixedArray::second($array) |
setSize | Resizes the array to a given size. | FixedArray::setSize(10, $array) |
toArray | Converts a fixed array into a standard array. | FixedArray::toArray($array) |
toCollection | Converts a fixed array into an Illuminate collection. | FixedArray::toCollection($array) |
Testing
Tests are run using Pest. You can run the suite like so:
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
We welcome pull requests, especially those improving the package's optimisation and speed, and new features to bring it into parity with Collection.
Please ensure any functionality submitted has adequate test coverage and documentation (at least in English.)
License
The MIT License (MIT). Please see License File for more information.