1
0
mirror of https://github.com/IBM/fp-go.git synced 2025-11-25 22:21:49 +02:00

initial checkin

Signed-off-by: Dr. Carsten Leue <carsten.leue@de.ibm.com>
This commit is contained in:
Dr. Carsten Leue
2023-07-07 22:31:06 +02:00
parent 71c47ca560
commit c07df5c771
128 changed files with 5827 additions and 2 deletions

29
magma/array.go Normal file
View File

@@ -0,0 +1,29 @@
package magma
import (
F "github.com/ibm/fp-go/function"
AR "github.com/ibm/fp-go/internal/array"
)
func GenericMonadConcatAll[GA ~[]A, A any](m Magma[A]) func(GA, A) A {
return func(as GA, first A) A {
return AR.Reduce(as, m.Concat, first)
}
}
// GenericConcatAll concats all items using the semigroup and a starting value
func GenericConcatAll[GA ~[]A, A any](m Magma[A]) func(A) func(GA) A {
ca := GenericMonadConcatAll[GA](m)
return func(a A) func(GA) A {
return F.Bind2nd(ca, a)
}
}
func MonadConcatAll[A any](m Magma[A]) func([]A, A) A {
return GenericMonadConcatAll[[]A](m)
}
// ConcatAll concats all items using the semigroup and a starting value
func ConcatAll[A any](m Magma[A]) func(A) func([]A) A {
return GenericConcatAll[[]A](m)
}