<?php /** * This file is part of the ramsey/collection library * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. * * @copyright Copyright (c) Ben Ramsey <ben@benramsey.com> * @license http://opensource.org/licenses/MIT MIT */ declare(strict_types=1); namespace Ramsey\Collection; /** * A collection represents a group of objects. * * Each object in the collection is of a specific, defined type. * * This is a direct implementation of `CollectionInterface`, provided for * the sake of convenience. * * Example usage: * * ``` php * $collection = new \Ramsey\Collection\Collection('My\\Foo'); * $collection->add(new \My\Foo()); * $collection->add(new \My\Foo()); * * foreach ($collection as $foo) { * // Do something with $foo * } * ``` * * It is preferable to subclass `AbstractCollection` to create your own typed * collections. For example: * * ``` php * namespace My\Foo; * * class FooCollection extends \Ramsey\Collection\AbstractCollection * { * public function getType() * { * return 'My\\Foo'; * } * } * ``` * * And then use it similarly to the earlier example: * * ``` php * $fooCollection = new \My\Foo\FooCollection(); * $fooCollection->add(new \My\Foo()); * $fooCollection->add(new \My\Foo()); * * foreach ($fooCollection as $foo) { * // Do something with $foo * } * ``` * * The benefit with this approach is that you may do type-checking on the * collection object: * * ``` php * if ($collection instanceof \My\Foo\FooCollection) { * // the collection is a collection of My\Foo objects * } * ``` * * @template T * @extends AbstractCollection<T> */ class Collection extends AbstractCollection { /** * Constructs a collection object of the specified type, optionally with the * specified data. * * @param string $collectionType The type or class name associated with this * collection. * @param array<array-key, T> $data The initial items to store in the collection. */ public function __construct(private readonly string $collectionType, array $data = []) { parent::__construct($data); } public function getType(): string { return $this->collectionType; } }
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
Exception | Folder | 0755 |
|
|
Map | Folder | 0755 |
|
|
Tool | Folder | 0755 |
|
|
AbstractArray.php | File | 4.44 KB | 0644 |
|
AbstractCollection.php | File | 12.2 KB | 0644 |
|
AbstractSet.php | File | 1.07 KB | 0644 |
|
ArrayInterface.php | File | 1.08 KB | 0644 |
|
Collection.php | File | 2.37 KB | 0644 |
|
CollectionInterface.php | File | 9.19 KB | 0644 |
|
DoubleEndedQueue.php | File | 4.35 KB | 0644 |
|
DoubleEndedQueueInterface.php | File | 10.42 KB | 0644 |
|
GenericArray.php | File | 536 B | 0644 |
|
Queue.php | File | 3.72 KB | 0644 |
|
QueueInterface.php | File | 7.41 KB | 0644 |
|
Set.php | File | 1.59 KB | 0644 |
|
Sort.php | File | 652 B | 0644 |
|