diff --git a/lib/iterator/batch.go b/lib/iterator/batch.go new file mode 100644 index 00000000..f7b193ca --- /dev/null +++ b/lib/iterator/batch.go @@ -0,0 +1,32 @@ +package iterator + +import "fmt" + +type batchIterator[T any] struct { + items []T + index int + step int +} + +// Returns an iterater that splits a list of items into batches of the given step size. +func NewBatchIterator[T any](items []T, step int) Iterator[[]T] { + return &batchIterator[T]{ + items: items, + index: 0, + step: max(step, 1), + } +} + +func (i *batchIterator[T]) HasNext() bool { + return i.index < len(i.items) +} + +func (i *batchIterator[T]) Next() ([]T, error) { + if !i.HasNext() { + return nil, fmt.Errorf("iterator has finished") + } + end := min(i.index+i.step, len(i.items)) + result := i.items[i.index:end] + i.index = end + return result, nil +} diff --git a/lib/iterator/iterator_test.go b/lib/iterator/batch_test.go similarity index 100% rename from lib/iterator/iterator_test.go rename to lib/iterator/batch_test.go diff --git a/lib/iterator/iterator.go b/lib/iterator/iterator.go index 58712fc5..9fbf9dd6 100644 --- a/lib/iterator/iterator.go +++ b/lib/iterator/iterator.go @@ -1,37 +1,6 @@ package iterator -import "fmt" - type Iterator[T any] interface { HasNext() bool Next() (T, error) } - -type batchIterator[T any] struct { - items []T - index int - step int -} - -// Returns an iterater that splits a list of items into batches of the given step size. -func NewBatchIterator[T any](items []T, step int) Iterator[[]T] { - return &batchIterator[T]{ - items: items, - index: 0, - step: max(step, 1), - } -} - -func (i *batchIterator[T]) HasNext() bool { - return i.index < len(i.items) -} - -func (i *batchIterator[T]) Next() ([]T, error) { - if !i.HasNext() { - return nil, fmt.Errorf("iterator has finished") - } - end := min(i.index+i.step, len(i.items)) - result := i.items[i.index:end] - i.index = end - return result, nil -}