1
0
mirror of https://github.com/IBM/fp-go.git synced 2025-07-03 00:47:05 +02:00
Files
fp-go/iterator/stateless/generic/scan.go
Dr. Carsten Leue 411caa6dff fix: add Take to Iterables
Signed-off-by: Dr. Carsten Leue <carsten.leue@de.ibm.com>
2023-08-03 15:32:27 +02:00

40 lines
1.2 KiB
Go

// Copyright (c) 2023 IBM Corp.
// All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package generic
import (
F "github.com/IBM/fp-go/function"
O "github.com/IBM/fp-go/option"
T "github.com/IBM/fp-go/tuple"
)
func Scan[GV ~func() O.Option[T.Tuple2[GV, V]], GU ~func() O.Option[T.Tuple2[GU, U]], FCT ~func(V, U) V, U, V any](f FCT, initial V) func(ma GU) GV {
// pre-declare to avoid cyclic reference
var recurse func(ma GU, v V) GV
recurse = func(ma GU, current V) GV {
return F.Nullary2(
ma,
O.Map(func(t T.Tuple2[GU, U]) T.Tuple2[GV, V] {
v := f(current, t.F2)
return T.MakeTuple2(recurse(t.F1, v), v)
}),
)
}
return F.Bind2nd(recurse, initial)
}