module Stdlib.Data.Result;
import Stdlib.Data.Result.Base open public;
import Stdlib.Data.Bool.Base open;
import Stdlib.Data.String.Base open;
import Stdlib.Data.Pair.Base open;
import Stdlib.Trait.Eq open;
import Stdlib.Trait.Ord open;
import Stdlib.Trait.Show open;
import Stdlib.Trait.Traversable open;
import Stdlib.Trait open;
deriving instance
ordResultI {Error Value} {{Ord Error}} {{Ord Value}} : Ord (Result Error Value);
deriving instance
eqResultI {Error Value} {{Eq Error}} {{Eq Value}} : Eq (Result Error Value);
instance
showResultI
{Error Value} {{Show Error}} {{Show Value}} : Show (Result Error Value) :=
mkShow@{
show : Result Error Value -> String
| (error x) := "Error (" ++str Show.show x ++str ")"
| (ok x) := "Ok (" ++str Show.show x ++str ")";
};
instance
functorResultI {Error} : Functor (Result Error) :=
mkFunctor@{
map := mapOk;
};
instance
monomorphicFunctorResultI
{Error Value} : Monomorphic.Functor (Result Error Value) Value :=
fromPolymorphicFunctor;
instance
applicativeResultI {Error} : Applicative (Result Error) :=
mkApplicative@{
pure := ok;
ap
{A B}
(resultFun : Result Error (A -> B))
(result : Result Error A)
: Result Error B :=
case resultFun, result of
| ok f, ok x := ok (f x)
| ok _, error e := error e
| error e, _ := error e;
};
instance
monadResultI {Error} : Monad (Result Error) :=
mkMonad@{
bind
{A B}
(result : Result Error A)
(fun : A -> Result Error B)
: Result Error B :=
case result of
| error e := error e
| ok a := fun a;
};
instance
traversableResultI {E} : Traversable (Result E) :=
mkTraversable@{
sequenceA
{F : Type -> Type}
{{Applicative F}}
{A}
: Result E (F A) -> F (Result E A)
| (error e) := pure (error e)
| (ok x) := map ok x;
traverse := defaultTraverse sequenceA;
};