PluginProbe ʕ •ᴥ•ʔ
ShareThis Dashboard for Google Analytics / trunk
ShareThis Dashboard for Google Analytics vtrunk
3.3.2 trunk 1.0.7 2.0.0 2.0.1 2.0.2 2.0.3 2.0.4 2.0.5 2.1 2.1.2 2.1.3 2.1.4 2.1.5 2.2.5 2.3.5 2.3.6 2.3.7 2.3.8 2.4.0 2.4.1 2.5.0 2.5.1 2.5.2 2.5.3 2.5.4 2.5.5 3.0.0 3.1.0 3.1.1 3.1.2 3.1.3 3.1.4 3.1.5 3.1.6 3.1.7 3.2.0 3.2.1 3.2.2 3.2.3 3.2.4 3.3.0 3.3.1
googleanalytics / lib / analytics-admin / vendor / ramsey / collection / src / Collection.php
googleanalytics / lib / analytics-admin / vendor / ramsey / collection / src Last commit date
Exception 3 years ago Map 3 years ago Tool 3 years ago AbstractArray.php 3 years ago AbstractCollection.php 3 years ago AbstractSet.php 3 years ago ArrayInterface.php 3 years ago Collection.php 3 years ago CollectionInterface.php 3 years ago DoubleEndedQueue.php 3 years ago DoubleEndedQueueInterface.php 3 years ago GenericArray.php 3 years ago Queue.php 3 years ago QueueInterface.php 3 years ago Set.php 3 years ago
Collection.php
107 lines
1 <?php
2
3 /**
4 * This file is part of the ramsey/collection library
5 *
6 * For the full copyright and license information, please view the LICENSE
7 * file that was distributed with this source code.
8 *
9 * @copyright Copyright (c) Ben Ramsey <ben@benramsey.com>
10 * @license http://opensource.org/licenses/MIT MIT
11 */
12
13 declare(strict_types=1);
14
15 namespace Ramsey\Collection;
16
17 /**
18 * A collection represents a group of objects.
19 *
20 * Each object in the collection is of a specific, defined type.
21 *
22 * This is a direct implementation of `CollectionInterface`, provided for
23 * the sake of convenience.
24 *
25 * Example usage:
26 *
27 * ``` php
28 * $collection = new \Ramsey\Collection\Collection('My\\Foo');
29 * $collection->add(new \My\Foo());
30 * $collection->add(new \My\Foo());
31 *
32 * foreach ($collection as $foo) {
33 * // Do something with $foo
34 * }
35 * ```
36 *
37 * It is preferable to subclass `AbstractCollection` to create your own typed
38 * collections. For example:
39 *
40 * ``` php
41 * namespace My\Foo;
42 *
43 * class FooCollection extends \Ramsey\Collection\AbstractCollection
44 * {
45 * public function getType()
46 * {
47 * return 'My\\Foo';
48 * }
49 * }
50 * ```
51 *
52 * And then use it similarly to the earlier example:
53 *
54 * ``` php
55 * $fooCollection = new \My\Foo\FooCollection();
56 * $fooCollection->add(new \My\Foo());
57 * $fooCollection->add(new \My\Foo());
58 *
59 * foreach ($fooCollection as $foo) {
60 * // Do something with $foo
61 * }
62 * ```
63 *
64 * The benefit with this approach is that you may do type-checking on the
65 * collection object:
66 *
67 * ``` php
68 * if ($collection instanceof \My\Foo\FooCollection) {
69 * // the collection is a collection of My\Foo objects
70 * }
71 * ```
72 *
73 * @template T
74 * @extends AbstractCollection<T>
75 */
76 class Collection extends AbstractCollection
77 {
78 /**
79 * The type of elements stored in this collection.
80 *
81 * A collection's type is immutable once it is set. For this reason, this
82 * property is set private.
83 *
84 * @var string
85 */
86 private $collectionType;
87
88 /**
89 * Constructs a collection object of the specified type, optionally with the
90 * specified data.
91 *
92 * @param string $collectionType The type (FQCN) associated with this
93 * collection.
94 * @param array<array-key, T> $data The initial items to store in the collection.
95 */
96 public function __construct(string $collectionType, array $data = [])
97 {
98 $this->collectionType = $collectionType;
99 parent::__construct($data);
100 }
101
102 public function getType(): string
103 {
104 return $this->collectionType;
105 }
106 }
107