Collection.php 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. <?php
  2. /**
  3. * CakePHP(tm) : Rapid Development Framework (http://cakephp.org)
  4. * Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
  5. *
  6. * Licensed under The MIT License
  7. * For full copyright and license information, please see the LICENSE.txt
  8. * Redistributions of files must retain the above copyright notice.
  9. *
  10. * @copyright Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
  11. * @link http://cakephp.org CakePHP(tm) Project
  12. * @since 3.0.0
  13. * @license http://www.opensource.org/licenses/mit-license.php MIT License
  14. */
  15. namespace Cake\Collection;
  16. use ArrayIterator;
  17. use Cake\Collection\CollectionInterface;
  18. use Cake\Collection\CollectionTrait;
  19. use InvalidArgumentException;
  20. use IteratorIterator;
  21. use JsonSerializable;
  22. /**
  23. * A collection is an immutable list of elements with a handful of functions to
  24. * iterate, group, transform and extract information from it.
  25. */
  26. class Collection extends IteratorIterator implements CollectionInterface {
  27. use CollectionTrait;
  28. /**
  29. * Constructor. You can provide an array or any traversable object
  30. *
  31. * @param array|\Traversable $items Items.
  32. * @throws InvalidArgumentException If passed incorrect type for items.
  33. */
  34. public function __construct($items) {
  35. if (is_array($items)) {
  36. $items = new ArrayIterator($items);
  37. }
  38. if (!($items instanceof \Traversable)) {
  39. $msg = 'Only an array or \Traversable is allowed for Collection';
  40. throw new InvalidArgumentException($msg);
  41. }
  42. parent::__construct($items);
  43. }
  44. }