2023-07-23 22:05:54 +02:00
|
|
|
// 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.
|
|
|
|
|
2023-07-14 23:52:14 +02:00
|
|
|
package readerioeither
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"time"
|
|
|
|
|
2023-07-18 15:57:54 +02:00
|
|
|
R "github.com/IBM/fp-go/context/reader"
|
|
|
|
RIO "github.com/IBM/fp-go/context/readerio"
|
|
|
|
G "github.com/IBM/fp-go/context/readerioeither/generic"
|
|
|
|
ET "github.com/IBM/fp-go/either"
|
|
|
|
IO "github.com/IBM/fp-go/io"
|
|
|
|
IOE "github.com/IBM/fp-go/ioeither"
|
|
|
|
O "github.com/IBM/fp-go/option"
|
2023-07-14 23:52:14 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
func FromEither[A any](e ET.Either[error, A]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.FromEither[ReaderIOEither[A]](e)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func RightReader[A any](r R.Reader[A]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.RightReader[ReaderIOEither[A]](r)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func LeftReader[A any](l R.Reader[error]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.LeftReader[ReaderIOEither[A]](l)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func Left[A any](l error) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.Left[ReaderIOEither[A]](l)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func Right[A any](r A) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.Right[ReaderIOEither[A]](r)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func FromReader[A any](r R.Reader[A]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.FromReader[ReaderIOEither[A]](r)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func MonadMap[A, B any](fa ReaderIOEither[A], f func(A) B) ReaderIOEither[B] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.MonadMap[ReaderIOEither[A], ReaderIOEither[B]](fa, f)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func Map[A, B any](f func(A) B) func(ReaderIOEither[A]) ReaderIOEither[B] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.Map[ReaderIOEither[A], ReaderIOEither[B]](f)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func MonadChain[A, B any](ma ReaderIOEither[A], f func(A) ReaderIOEither[B]) ReaderIOEither[B] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.MonadChain(ma, f)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func Chain[A, B any](f func(A) ReaderIOEither[B]) func(ReaderIOEither[A]) ReaderIOEither[B] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.Chain[ReaderIOEither[A]](f)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
2023-07-15 23:27:45 +02:00
|
|
|
func MonadChainFirst[A, B any](ma ReaderIOEither[A], f func(A) ReaderIOEither[B]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.MonadChainFirst(ma, f)
|
2023-07-15 23:27:45 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func ChainFirst[A, B any](f func(A) ReaderIOEither[B]) func(ReaderIOEither[A]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.ChainFirst[ReaderIOEither[A]](f)
|
2023-07-15 23:27:45 +02:00
|
|
|
}
|
|
|
|
|
2023-07-14 23:52:14 +02:00
|
|
|
func Of[A any](a A) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.Of[ReaderIOEither[A]](a)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// MonadAp implements the `Ap` function for a reader with context. It creates a sub-context that will
|
|
|
|
// be canceled if any of the input operations errors out or
|
2023-07-18 15:24:00 +02:00
|
|
|
func MonadAp[B, A any](fab ReaderIOEither[func(A) B], fa ReaderIOEither[A]) ReaderIOEither[B] {
|
|
|
|
return G.MonadAp[ReaderIOEither[B]](fab, fa)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
2023-07-18 15:24:00 +02:00
|
|
|
func Ap[B, A any](fa ReaderIOEither[A]) func(ReaderIOEither[func(A) B]) ReaderIOEither[B] {
|
|
|
|
return G.Ap[ReaderIOEither[B], ReaderIOEither[func(A) B]](fa)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func FromPredicate[A any](pred func(A) bool, onFalse func(A) error) func(A) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.FromPredicate[ReaderIOEither[A]](pred, onFalse)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func Fold[A, B any](onLeft func(error) RIO.ReaderIO[B], onRight func(A) RIO.ReaderIO[B]) func(ReaderIOEither[A]) RIO.ReaderIO[B] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.Fold[RIO.ReaderIO[B], ReaderIOEither[A]](onLeft, onRight)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func GetOrElse[A any](onLeft func(error) RIO.ReaderIO[A]) func(ReaderIOEither[A]) RIO.ReaderIO[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.GetOrElse[RIO.ReaderIO[A], ReaderIOEither[A]](onLeft)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func OrElse[A any](onLeft func(error) ReaderIOEither[A]) func(ReaderIOEither[A]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.OrElse[ReaderIOEither[A]](onLeft)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func OrLeft[A any](onLeft func(error) RIO.ReaderIO[error]) func(ReaderIOEither[A]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.OrLeft[ReaderIOEither[A], RIO.ReaderIO[error]](onLeft)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func Ask() ReaderIOEither[context.Context] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.Ask[ReaderIOEither[context.Context]]()
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func Asks[A any](r R.Reader[A]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.Asks[ReaderIOEither[A]](r)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func MonadChainEitherK[A, B any](ma ReaderIOEither[A], f func(A) ET.Either[error, B]) ReaderIOEither[B] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.MonadChainEitherK[ReaderIOEither[A], ReaderIOEither[B]](ma, f)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func ChainEitherK[A, B any](f func(A) ET.Either[error, B]) func(ma ReaderIOEither[A]) ReaderIOEither[B] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.ChainEitherK[ReaderIOEither[A], ReaderIOEither[B]](f)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
2023-07-15 23:27:45 +02:00
|
|
|
func MonadChainFirstEitherK[A, B any](ma ReaderIOEither[A], f func(A) ET.Either[error, B]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.MonadChainFirstEitherK[ReaderIOEither[A]](ma, f)
|
2023-07-15 23:27:45 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func ChainFirstEitherK[A, B any](f func(A) ET.Either[error, B]) func(ma ReaderIOEither[A]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.ChainFirstEitherK[ReaderIOEither[A]](f)
|
2023-07-15 23:27:45 +02:00
|
|
|
}
|
|
|
|
|
2023-07-14 23:52:14 +02:00
|
|
|
func ChainOptionK[A, B any](onNone func() error) func(func(A) O.Option[B]) func(ReaderIOEither[A]) ReaderIOEither[B] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.ChainOptionK[ReaderIOEither[A], ReaderIOEither[B]](onNone)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func FromIOEither[A any](t IOE.IOEither[error, A]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.FromIOEither[ReaderIOEither[A]](t)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func FromIO[A any](t IO.IO[A]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.FromIO[ReaderIOEither[A]](t)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Never returns a 'ReaderIOEither' that never returns, except if its context gets canceled
|
|
|
|
func Never[A any]() ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.Never[ReaderIOEither[A]]()
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func MonadChainIOK[A, B any](ma ReaderIOEither[A], f func(A) IO.IO[B]) ReaderIOEither[B] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.MonadChainIOK[ReaderIOEither[B], ReaderIOEither[A]](ma, f)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func ChainIOK[A, B any](f func(A) IO.IO[B]) func(ma ReaderIOEither[A]) ReaderIOEither[B] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.ChainIOK[ReaderIOEither[B], ReaderIOEither[A]](f)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
2023-07-15 23:27:45 +02:00
|
|
|
func MonadChainFirstIOK[A, B any](ma ReaderIOEither[A], f func(A) IO.IO[B]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.MonadChainFirstIOK[ReaderIOEither[A]](ma, f)
|
2023-07-15 23:27:45 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func ChainFirstIOK[A, B any](f func(A) IO.IO[B]) func(ma ReaderIOEither[A]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.ChainFirstIOK[ReaderIOEither[A]](f)
|
2023-07-15 23:27:45 +02:00
|
|
|
}
|
|
|
|
|
2023-07-14 23:52:14 +02:00
|
|
|
func ChainIOEitherK[A, B any](f func(A) IOE.IOEither[error, B]) func(ma ReaderIOEither[A]) ReaderIOEither[B] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.ChainIOEitherK[ReaderIOEither[A], ReaderIOEither[B]](f)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Delay creates an operation that passes in the value after some delay
|
|
|
|
func Delay[A any](delay time.Duration) func(ma ReaderIOEither[A]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.Delay[ReaderIOEither[A]](delay)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Timer will return the current time after an initial delay
|
|
|
|
func Timer(delay time.Duration) ReaderIOEither[time.Time] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.Timer[ReaderIOEither[time.Time]](delay)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Defer creates an IO by creating a brand new IO via a generator function, each time
|
|
|
|
func Defer[A any](gen func() ReaderIOEither[A]) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.Defer[ReaderIOEither[A]](gen)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// TryCatch wraps a reader returning a tuple as an error into ReaderIOEither
|
|
|
|
func TryCatch[A any](f func(context.Context) func() (A, error)) ReaderIOEither[A] {
|
2023-07-18 15:24:00 +02:00
|
|
|
return G.TryCatch[ReaderIOEither[A]](f)
|
2023-07-14 23:52:14 +02:00
|
|
|
}
|