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: |