2023-07-07 22:31:06 +02:00
|
|
|
package either
|
|
|
|
|
|
|
|
import (
|
|
|
|
M "github.com/ibm/fp-go/monoid"
|
|
|
|
S "github.com/ibm/fp-go/semigroup"
|
|
|
|
)
|
|
|
|
|
|
|
|
func ApplySemigroup[E, A any](s S.Semigroup[A]) S.Semigroup[Either[E, A]] {
|
2023-07-14 13:20:00 +02:00
|
|
|
return S.ApplySemigroup(MonadMap[E, A, func(A) A], MonadAp[A, E, A], s)
|
2023-07-07 22:31:06 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func ApplicativeMonoid[E, A any](m M.Monoid[A]) M.Monoid[Either[E, A]] {
|
2023-07-14 13:20:00 +02:00
|
|
|
return M.ApplicativeMonoid(Of[E, A], MonadMap[E, A, func(A) A], MonadAp[A, E, A], m)
|
2023-07-07 22:31:06 +02:00
|
|
|
}
|