1: <?php
2:
3: declare(strict_types=1);
4:
5: /**
6: * This file is part of the Nexus framework.
7: *
8: * (c) John Paul E. Balandan, CPA <paulbalandan@gmail.com>
9: *
10: * For the full copyright and license information, please view
11: * the LICENSE file that was distributed with this source code.
12: */
13:
14: namespace Nexus\Collection\Operation;
15:
16: use Nexus\Collection\CollectionInterface;
17:
18: /**
19: * @template TKey
20: * @template T
21: */
22: interface Chunk
23: {
24: /**
25: * Returns a new collection containing the original items in the
26: * collection split into chunks of given `$size`.
27: *
28: * This chunking operation preserves the keys. If the original
29: * collection does not split evenly, the final chunk will be
30: * smaller.
31: *
32: * @param int<1, max> $size
33: *
34: * @return CollectionInterface<int, non-empty-array<TKey, T>>
35: */
36: public function chunk(int $size): CollectionInterface;
37: }
38: