Deprecated: With the separation of Illuminate's Collections package, Collect is no longer necessary 🎉 . We will maintain it for the 8.0 and 9.0 releases of Laravel for the convenience of package maintainers, and will stop mirroring new major versions after 9.0, but keep the existing package here for continued support.
Import Laravel's Collections into non-Laravel packages easily, without needing to require the entire Illuminate\Support
package. (Why not pull Illuminate\Support
in framework-agnostic packages)
Written by Taylor Otwell as a part of Laravel's Illuminate/Support package, Collect is just the code from Support needed in order to use Collections on their own.
Lovingly split by Matt Stauffer for Tighten Co., with a kick in the butt to finally do it from @assertchris.
With Composer:
composer require tightenco/collect
If you are a developer working on Collect and you're tasked with upgrading it to mirror a new version of Laravel, run ./upgrade.sh
from the root directory. You can pass a parameter to target a specific Laravel version (e.g. ./upgrade.sh 5.7.10
) or, if you don't pass a parameter, the script will find the latest tagged release and run against that.
The upgrader will pull down the appropriate source and test files for the specified version of Laravel and then run the tests.
./upgrade.sh
# or
./upgrade.sh 5.7.10
The upgrade script requires the use of
wget
. It's recommended to install homebrew, and runbrew install wget
Due to a dependency on Carbon, tests won't pass until you've run ./upgrade.sh
at least once locally.
vendor/bin/phpunit
- Has this ever, or will it ever, develop independently from Illuminate's Collections?
No. Using an upgrade script, it's split automatically with every Laravel release to keep it in sync with Laravel's Collections, even mirroring the release numbers. - Why is the package
tightenco/collect
instead ofilluminate/collect
?
It's not an official Laravel package so we don't want to use the Packagist namespace reserved by Laravel packages.One dayNow thatCollection
may be extracted fromilluminate/support
to a new package. If so, we'll deprecate this package and point to the core version.illuminate/collections
has been released, we're deprecating this package. - Why not just use an array?
What a great question. Tighten alum Adam Wathan has a book about that.
The Laravel framework is open-sourced software licensed under the MIT license. Collect consists almost entirely of Laravel source code, so maintains the same license.