Documentation ¶
Overview ¶
Package loop provides helpers for loop operation and iterator implementations
Index ¶
- Variables
- func Append[T any, TS ~[]T](next func() (T, bool, error), out TS) (TS, error)
- func Contains[T comparable](next func() (T, bool, error), example T) (bool, error)
- func ConvAndReduce[From, To any](next func() (From, bool, error), converter func(From) (To, error), ...) (out To, err error)
- func ConvertAndReduce[From, To any](next func() (From, bool, error), converter func(From) To, ...) (out To, err error)
- func First[T any](next func() (T, bool, error), predicate func(T) bool) (T, bool, error)
- func Firstt[T any](next func() (T, bool, error), predicate func(T) (bool, error)) (T, bool, error)
- func For[T any](next func() (T, bool, error), walker func(T) error) error
- func ForFiltered[T any](next func() (T, bool, error), walker func(T) error, predicate func(T) bool) error
- func From[T any](next func() (T, bool)) func() (T, bool, error)
- func Group[T any, K comparable, V any](next func() (T, bool, error), keyExtractor func(T) (K, error), ...) (map[K][]V, error)
- func GroupByMultiple[T any, K comparable, V any](next func() (T, bool, error), keysExtractor func(T) []K, ...) (map[K][]V, error)
- func GroupByMultipleKeys[T any, K comparable, V any](next func() (T, bool, error), keysExtractor func(T) []K, ...) (map[K][]V, error)
- func GroupByMultipleValues[T any, K comparable, V any](next func() (T, bool, error), keyExtractor func(T) K, ...) (map[K][]V, error)
- func HasAny[T any](next func() (T, bool, error), predicate func(T) bool) (bool, error)
- func HasAnyy[T any](next func() (T, bool, error), predicate func(T) (bool, error)) (bool, error)
- func New[S, T any](source S, hasNext func(S) bool, getNext func(S) (T, error)) func() (T, bool, error)
- func Of[T any](elements ...T) func() (e T, ok bool, err error)
- func Reduce[T any](next func() (T, bool, error), merger func(T, T) T) (out T, e error)
- func Reducee[T any](next func() (T, bool, error), merger func(T, T) (T, error)) (out T, e error)
- func Slice[T any](next func() (T, bool, error)) (out []T, err error)
- func SliceCap[T any](next func() (T, bool, error), cap int) (out []T, err error)
- func Sum[T c.Summable](next func() (T, bool, error)) (T, error)
- func To[T any](next func() (T, bool, error), errConsumer func(error)) func() (T, bool)
- func ToMapResolv[T any, K comparable, V, VR any](next func() (T, bool, error), keyExtractor func(T) (K, error), ...) (m map[K]VR, err error)
- func Track[I, T any](next func() (I, T, bool, error), tracker func(I, T) error) error
- type ConvertCheckIter
- func ConvCheck[From, To any](next func() (From, bool, error), converter func(from From) (To, bool, error)) ConvertCheckIter[From, To]
- func ConvertCheck[From, To any](next func() (From, bool, error), converter func(from From) (To, bool)) ConvertCheckIter[From, To]
- func GetValues[T any](next func() (*T, bool, error)) ConvertCheckIter[*T, T]
- type ConvertFitIter
- func ConvertAndFilter[From, To any](next func() (From, bool, error), converter func(From) (To, error), ...) ConvertFitIter[From, To]
- func FilterAndConvert[From, To any](next func() (From, bool, error), filter func(From) bool, ...) ConvertFitIter[From, To]
- func FilterConvertFilter[From, To any](next func() (From, bool, error), filter func(From) (bool, error), ...) ConvertFitIter[From, To]
- func FitAndConv[From, To any](next func() (From, bool, error), filter func(From) (bool, error), ...) ConvertFitIter[From, To]
- type ConvertIter
- type FiltIter
- type FlatIter
- type FlattenFitIter
- func FilterAndFlatt[From, To any](next func() (From, bool, error), filter func(From) bool, ...) FlattenFitIter[From, To]
- func FilterFlattFilter[From, To any](next func() (From, bool, error), filterFrom func(From) bool, ...) FlattenFitIter[From, To]
- func FitAndFlat[From, To any](next func() (From, bool, error), filter func(From) (bool, error), ...) FlattenFitIter[From, To]
- func FitFlatFit[From, To any](next func() (From, bool, error), filterFrom func(From) (bool, error), ...) FlattenFitIter[From, To]
- func FlatAndFit[From, To any](next func() (From, bool, error), flattener func(From) ([]To, error), ...) FlattenFitIter[From, To]
- func FlattAndFilter[From, To any](next func() (From, bool, error), flattener func(From) []To, ...) FlattenFitIter[From, To]
- type KeyValuer
- type Looper
- type MultipleKeyValuer
- func FlatKeys[T, K, V any](next func() (T, bool, error), keysExtractor func(T) ([]K, error), ...) *MultipleKeyValuer[T, K, V]
- func FlatValues[T, K, V any](next func() (T, bool, error), keyExtractor func(T) (K, error), ...) *MultipleKeyValuer[T, K, V]
- func FlattKeys[T, K, V any](next func() (T, bool, error), keysExtractor func(T) []K, ...) *MultipleKeyValuer[T, K, V]
- func FlattValues[T, K, V any](next func() (T, bool, error), keyExtractor func(T) K, ...) *MultipleKeyValuer[T, K, V]
- func NewMultipleKeyValuer[T any, K, V any](next func() (T, bool, error), keysExtractor func(T) ([]K, error), ...) MultipleKeyValuer[T, K, V]
- func ToKVs[T, K, V any](next func() (T, bool, error), keysExtractor func(T) ([]K, error), ...) *MultipleKeyValuer[T, K, V]
Constants ¶
This section is empty.
Variables ¶
var ErrBreak = c.ErrBreak
ErrBreak is the 'break' statement of the For, Track methods
Functions ¶
func Append ¶ added in v0.0.8
Append collects the elements retrieved by the 'next' function into the specified 'out' slice
func Contains ¶
func Contains[T comparable](next func() (T, bool, error), example T) (bool, error)
Contains finds the first element that equal to the example and returns true
func ConvAndReduce ¶ added in v0.0.8
func ConvAndReduce[From, To any](next func() (From, bool, error), converter func(From) (To, error), merger func(To, To) To) (out To, err error)
ConvAndReduce converts each elements and merges them into one
func ConvertAndReduce ¶ added in v0.0.8
func ConvertAndReduce[From, To any](next func() (From, bool, error), converter func(From) To, merger func(To, To) To) (out To, err error)
ConvertAndReduce converts each elements and merges them into one
func First ¶
First returns the first element that satisfies the condition of the 'predicate' function
func Firstt ¶ added in v0.0.8
Firstt returns the first element that satisfies the condition of the 'predicate' function
func For ¶
For applies the 'walker' function for the elements retrieved by the 'next' function. Return the c.ErrBreak to stop
func ForFiltered ¶
func ForFiltered[T any](next func() (T, bool, error), walker func(T) error, predicate func(T) bool) error
ForFiltered applies the 'walker' function to the elements retrieved by the 'next' function that satisfy the 'predicate' function condition
func Group ¶
func Group[T any, K comparable, V any](next func() (T, bool, error), keyExtractor func(T) (K, error), valExtractor func(T) (V, error)) (map[K][]V, error)
Group converts elements retrieved by the 'next' function into a map, extracting a key for each element applying the converter 'keyExtractor'. The keyExtractor converts an element to a key. The valExtractor converts an element to an value.
func GroupByMultiple ¶
func GroupByMultiple[T any, K comparable, V any](next func() (T, bool, error), keysExtractor func(T) []K, valsExtractor func(T) []V) (map[K][]V, error)
GroupByMultiple converts elements retrieved by the 'next' function into a map, extracting multiple keys, values per each element applying the 'keysExtractor' and 'valsExtractor' functions. The keysExtractor retrieves one or more keys per element. The valsExtractor retrieves one or more values per element.
func GroupByMultipleKeys ¶
func GroupByMultipleKeys[T any, K comparable, V any](next func() (T, bool, error), keysExtractor func(T) []K, valExtractor func(T) V) (map[K][]V, error)
GroupByMultipleKeys converts elements retrieved by the 'next' function into a map, extracting multiple keys, one value per each element applying the 'keysExtractor' and 'valExtractor' functions. The keysExtractor retrieves one or more keys per element. The valExtractor converts an element to a value.
func GroupByMultipleValues ¶
func GroupByMultipleValues[T any, K comparable, V any](next func() (T, bool, error), keyExtractor func(T) K, valsExtractor func(T) []V) (map[K][]V, error)
GroupByMultipleValues converts elements retrieved by the 'next' function into a map, extracting one key, multiple values per each element applying the 'keyExtractor' and 'valsExtractor' functions. The keyExtractor converts an element to a key. The valsExtractor retrieves one or more values per element.
func HasAny ¶
HasAny finds the first element that satisfies the 'predicate' function condition and returns true if successful
func HasAnyy ¶ added in v0.0.8
HasAnyy finds the first element that satisfies the 'predicate' function condition and returns true if successful
func New ¶
func New[S, T any](source S, hasNext func(S) bool, getNext func(S) (T, error)) func() (T, bool, error)
New is the main breakable loop constructor
func Reduce ¶
Reduce reduces the elements retrieved by the 'next' function into an one using the 'merge' function
func Reducee ¶ added in v0.0.8
Reducee reduces the elements retrieved by the 'next' function into an one using the 'merge' function
func SliceCap ¶ added in v0.0.8
SliceCap collects the elements retrieved by the 'next' function into a new slice with predefined capacity
func To ¶
To transforms a breakable loop to a simple loop. The errConsumer is a function that is called when an error occurs.
func ToMapResolv ¶
func ToMapResolv[T any, K comparable, V, VR any]( next func() (T, bool, error), keyExtractor func(T) (K, error), valExtractor func(T) (V, error), resolver func(bool, K, VR, V) (VR, error), ) (m map[K]VR, err error)
ToMapResolv collects key\value elements to a map by iterating over the elements with resolving of duplicated key values
Types ¶
type ConvertCheckIter ¶
type ConvertCheckIter[From, To any] struct { // contains filtered or unexported fields }
ConvertCheckIter converts and filters elements at the same time
func ConvCheck ¶
func ConvCheck[From, To any](next func() (From, bool, error), converter func(from From) (To, bool, error)) ConvertCheckIter[From, To]
ConvCheck is similar to ConvertFit, but it checks and transforms elements together
func ConvertCheck ¶
func ConvertCheck[From, To any](next func() (From, bool, error), converter func(from From) (To, bool)) ConvertCheckIter[From, To]
ConvertCheck is similar to ConvFit, but it checks and transforms elements together
func GetValues ¶
func GetValues[T any](next func() (*T, bool, error)) ConvertCheckIter[*T, T]
GetValues creates an iterator that transform only not nil pointers to the values referenced referenced by those pointers. Nil pointers are ignored.
func (ConvertCheckIter[From, To]) Next ¶
func (c ConvertCheckIter[From, To]) Next() (t To, ok bool, err error)
Next returns the next element. The ok result indicates whether the element was returned by the iterator. If ok == false, then the iteration must be completed.
type ConvertFitIter ¶
type ConvertFitIter[From, To any] struct { // contains filtered or unexported fields }
ConvertFitIter iterator implementation that retrieves an element by the 'next' function, converts by the 'converter' and addition checks by the 'filter'. If the filter returns true then the converted element is returned as next.
func ConvertAndFilter ¶
func ConvertAndFilter[From, To any](next func() (From, bool, error), converter func(From) (To, error), filter func(To) (bool, error)) ConvertFitIter[From, To]
ConvertAndFilter additionally filters 'To' elements
func FilterAndConvert ¶
func FilterAndConvert[From, To any](next func() (From, bool, error), filter func(From) bool, converter func(From) To) ConvertFitIter[From, To]
FilterAndConvert returns a stream that filters source elements and converts them
func FilterConvertFilter ¶
func FilterConvertFilter[From, To any](next func() (From, bool, error), filter func(From) (bool, error), converter func(From) (To, error), filterTo func(To) (bool, error)) ConvertFitIter[From, To]
FilterConvertFilter filters source, converts, and filters converted elements
func FitAndConv ¶
func FitAndConv[From, To any](next func() (From, bool, error), filter func(From) (bool, error), converter func(From) (To, error)) ConvertFitIter[From, To]
FitAndConv returns a stream that filters source elements and converts them
func (ConvertFitIter[From, To]) For ¶
func (c ConvertFitIter[From, To]) For(walker func(element To) error) error
For takes elements retrieved by the iterator. Can be interrupt by returning ErrBreak
func (ConvertFitIter[From, To]) Next ¶
func (c ConvertFitIter[From, To]) Next() (t To, ok bool, err error)
Next returns the next element. The ok result indicates whether the element was returned by the iterator. If ok == false, then the iteration must be completed.
type ConvertIter ¶
type ConvertIter[From, To any] struct { // contains filtered or unexported fields }
ConvertIter iterator implementation that retrieves an element by the 'next' function and converts by the 'converter'
func Conv ¶
func Conv[From, To any](next func() (From, bool, error), converter func(From) (To, error)) ConvertIter[From, To]
Conv instantiates an iterator that converts elements with a converter and returns them.
func Convert ¶
func Convert[From, To any](next func() (From, bool, error), converter func(From) To) ConvertIter[From, To]
Convert instantiates an iterator that converts elements with a converter and returns them.
func ToValues ¶
func ToValues[T any](next func() (*T, bool, error)) ConvertIter[*T, T]
ToValues creates an iterator that transform pointers to the values referenced referenced by those pointers. Nil pointers are transformet to zero values.
func (ConvertIter[From, To]) For ¶
func (c ConvertIter[From, To]) For(walker func(element To) error) error
For takes elements retrieved by the iterator. Can be interrupt by returning ErrBreak
func (ConvertIter[From, To]) Next ¶
func (c ConvertIter[From, To]) Next() (t To, ok bool, err error)
Next returns the next element. The ok result indicates whether the element was returned by the iterator. If ok == false, then the iteration must be completed.
type FiltIter ¶
type FiltIter[T any] struct { // contains filtered or unexported fields }
FiltIter is the Iterator wrapper that provides filtering of elements by a Predicate.
func Filt ¶
Filt creates an iterator that checks elements by the 'filter' function and returns successful ones.
func Filter ¶
Filter creates an iterator that checks elements by the 'filter' function and returns successful ones.
type FlatIter ¶
type FlatIter[From, To any] struct { // contains filtered or unexported fields }
FlatIter is the Iterator wrapper that converts an element to a slice and iterates over the elements of that slice. For example, FlatIter can be used to iterate over all the elements of a multi-dimensional array as if it were a one-dimensional array ([][]int -> []int).
func Flat ¶
func Flat[From, To any](next func() (From, bool, error), flattener func(From) ([]To, error)) FlatIter[From, To]
Flat instantiates an iterator that extracts slices of 'To' by a flattener from elements of 'From' and flattens as one iterable collection of 'To' elements.
func Flatt ¶
func Flatt[From, To any](next func() (From, bool, error), flattener func(From) []To) FlatIter[From, To]
Flatt instantiates an iterator that extracts slices of 'To' by a flattener from elements of 'From' and flattens as one iterable collection of 'To' elements.
type FlattenFitIter ¶
type FlattenFitIter[From, To any] struct { // contains filtered or unexported fields }
FlattenFitIter is the Iterator wrapper that converts an element to a slice with addition filtering of the element by a Predicate and iterates over the slice.
func FilterAndFlatt ¶
func FilterAndFlatt[From, To any](next func() (From, bool, error), filter func(From) bool, flattener func(From) []To) FlattenFitIter[From, To]
FilterAndFlatt filters source elements and extracts slices of 'To' by the 'flattener' function
func FilterFlattFilter ¶
func FilterFlattFilter[From, To any](next func() (From, bool, error), filterFrom func(From) bool, flattener func(From) []To, filterTo func(To) bool) FlattenFitIter[From, To]
FilterFlattFilter filters source elements, extracts slices of 'To' by the 'flattener' function and filters extracted elements
func FitAndFlat ¶
func FitAndFlat[From, To any](next func() (From, bool, error), filter func(From) (bool, error), flattener func(From) ([]To, error)) FlattenFitIter[From, To]
FitAndFlat filters source elements and extracts slices of 'To' by the 'flattener' function
func FitFlatFit ¶
func FitFlatFit[From, To any](next func() (From, bool, error), filterFrom func(From) (bool, error), flattener func(From) ([]To, error), filterTo func(To) (bool, error)) FlattenFitIter[From, To]
FitFlatFit filters source elements, extracts slices of 'To' by the 'flattener' function and filters extracted elements
func FlatAndFit ¶
func FlatAndFit[From, To any](next func() (From, bool, error), flattener func(From) ([]To, error), filterTo func(To) (bool, error)) FlattenFitIter[From, To]
FlatAndFit extracts slices of 'To' by the 'flattener' function and filters extracted elements
func FlattAndFilter ¶
func FlattAndFilter[From, To any](next func() (From, bool, error), flattener func(From) []To, filterTo func(To) bool) FlattenFitIter[From, To]
FlattAndFilter extracts slices of 'To' by the 'flattener' function and filters extracted elements
func (*FlattenFitIter[From, To]) For ¶
func (i *FlattenFitIter[From, To]) For(walker func(element To) error) error
For takes elements retrieved by the iterator. Can be interrupt by returning ErrBreak
func (*FlattenFitIter[From, To]) Next ¶
func (i *FlattenFitIter[From, To]) Next() (t To, ok bool, err error)
Next returns the next element. The ok result indicates whether the element was returned by the iterator. If ok == false, then the iteration must be completed.
type KeyValuer ¶
type KeyValuer[T, K, V any] struct { // contains filtered or unexported fields }
KeyValuer is the Iterator wrapper that converts an element to a key\value pair and iterates over these pairs
func NewKeyValuer ¶
func NewKeyValuer[T any, K, V any](next func() (T, bool, error), keyExtractor func(T) (K, error), valsExtractor func(T) (V, error)) KeyValuer[T, K, V]
NewKeyValuer creates instance of the KeyValuer
func ToKV ¶
func ToKV[T any, K comparable, V any](next func() (T, bool, error), keyExtractor func(T) (K, error), valExtractor func(T) (V, error)) KeyValuer[T, K, V]
ToKV transforms iterable elements to key/value iterator based on applying key, value extractors to the elements
type MultipleKeyValuer ¶
type MultipleKeyValuer[T, K, V any] struct { // contains filtered or unexported fields }
MultipleKeyValuer is the Iterator wrapper that converts an element to a key\value pair and iterates over these pairs
func FlatKeys ¶
func FlatKeys[T, K, V any](next func() (T, bool, error), keysExtractor func(T) ([]K, error), valExtractor func(T) (V, error)) *MultipleKeyValuer[T, K, V]
FlatKeys transforms iterable elements to key/value iterator based on applying key, value extractor to the elements
func FlatValues ¶
func FlatValues[T, K, V any](next func() (T, bool, error), keyExtractor func(T) (K, error), valsExtractor func(T) ([]V, error)) *MultipleKeyValuer[T, K, V]
FlatValues transforms iterable elements to key/value iterator based on applying key, value extractor to the elements
func FlattKeys ¶
func FlattKeys[T, K, V any](next func() (T, bool, error), keysExtractor func(T) []K, valExtractor func(T) V) *MultipleKeyValuer[T, K, V]
FlattKeys transforms iterable elements to key/value iterator based on applying key, value extractor to the elements
func FlattValues ¶
func FlattValues[T, K, V any](next func() (T, bool, error), keyExtractor func(T) K, valsExtractor func(T) []V) *MultipleKeyValuer[T, K, V]
FlattValues transforms iterable elements to key/value iterator based on applying key, value extractor to the elements
func NewMultipleKeyValuer ¶
func NewMultipleKeyValuer[T any, K, V any](next func() (T, bool, error), keysExtractor func(T) ([]K, error), valsExtractor func(T) ([]V, error)) MultipleKeyValuer[T, K, V]
NewMultipleKeyValuer creates instance of the MultipleKeyValuer
func ToKVs ¶
func ToKVs[T, K, V any](next func() (T, bool, error), keysExtractor func(T) ([]K, error), valsExtractor func(T) ([]V, error)) *MultipleKeyValuer[T, K, V]
ToKVs transforms iterable elements to key/value iterator based on applying key, value extractor to the elements
func (*MultipleKeyValuer[T, K, V]) Next ¶
func (kv *MultipleKeyValuer[T, K, V]) Next() (key K, value V, ok bool, err error)
Next returns the next element. The ok result indicates whether the element was returned by the iterator. If ok == false, then the iteration must be completed.
func (*MultipleKeyValuer[T, K, V]) Track ¶
func (kv *MultipleKeyValuer[T, K, V]) Track(traker func(key K, value V) error) error
Track takes key, value pairs retrieved by the iterator. Can be interrupt by returning ErrBreak