Module WithError.WithEnv
Locks in the reader environment type, so that we can implement the single-type-parameter type classes.
Parameters
- R: BsBastet.Interface.TYPE
Signature
- let make: ('a => M.t('b)) => t('a, 'b);
- let runRIO: 'a => t('a, 'b) => M.t('b);
- let mapRIO: (M.t('a) => M.t('b)) => t('c, 'a) => t('c, 'b);
- let withRIO: ('a => 'b) => t('b, 'c) => t('a, 'c);
- let ask: t('a, 'a);
- let asks: ('a => 'b) => t('a, 'b);
- let local: ('a => 'a) => t('a, 'b) => t('a, 'b);
- let semiflatMap: ('a => M.t('b)) => t('c, 'a) => t('c, 'b);
include { ... };
module BsFunctorExtensions: { ... };include { ... };
module BsApplyExtensions: { ... };- let applyFirst: Apply.t('a) => Apply.t('b) => Apply.t('a);
- let applySecond: Apply.t('a) => Apply.t('b) => Apply.t('b);
- let map2: ('a => 'b => 'c) => Apply.t('a) => Apply.t('b) => Apply.t('c);
- let map3: ('a => 'b => 'c => 'd) => Apply.t('a) => Apply.t('b) => Apply.t('c) => Apply.t('d);
- let map4: ('a => 'b => 'c => 'd => 'e) => Apply.t('a) => Apply.t('b) => Apply.t('c) => Apply.t('d) => Apply.t('e);
- let map5: ('a => 'b => 'c => 'd => 'e => 'f) => Apply.t('a) => Apply.t('b) => Apply.t('c) => Apply.t('d) => Apply.t('e) => Apply.t('f);
- let tuple2: Apply.t('a) => Apply.t('b) => Apply.t(('a, 'b));
- let tuple3: Apply.t('a) => Apply.t('b) => Apply.t('c) => Apply.t(('a, 'b, 'c));
- let tuple4: Apply.t('a) => Apply.t('b) => Apply.t('c) => Apply.t('d) => Apply.t(('a, 'b, 'c, 'd));
- let tuple5: Apply.t('a) => Apply.t('b) => Apply.t('c) => Apply.t('d) => Apply.t('e) => Apply.t(('a, 'b, 'c, 'd, 'e));
- let mapTuple2: ('a => 'b => 'c) => (Apply.t('a), Apply.t('b)) => Apply.t('c);
- let mapTuple3: ('a => 'b => 'c => 'd) => (Apply.t('a), Apply.t('b), Apply.t('c)) => Apply.t('d);
- let mapTuple4: ('a => 'b => 'c => 'd => 'e) => (Apply.t('a), Apply.t('b), Apply.t('c), Apply.t('d)) => Apply.t('e);
- let mapTuple5: ('a => 'b => 'c => 'd => 'e => 'f) => (Apply.t('a), Apply.t('b), Apply.t('c), Apply.t('d), Apply.t('e)) => Apply.t('f);
module Applicative: BsBastet.Interface.APPLICATIVE with type Applicative.t('a) = t('a);- let pure: 'a => Applicative.t('a);
include { ... };
module BsApplicativeExtensions: { ... };- let liftA1: ('a => 'b) => Applicative.t('a) => Applicative.t('b);
- let when_: bool => Applicative.t(unit) => Applicative.t(unit);
- let unless: bool => Applicative.t(unit) => Applicative.t(unit);
- let all: list(Applicative.t('a)) => Applicative.t(list('a));
include { ... };
module BsMonadExtensions: { ... };- let flatMap: ('a => Monad.t('b)) => Monad.t('a) => Monad.t('b);
- let flatten: Monad.t(Monad.t('a)) => Monad.t('a);
- let composeKleisli: ('a => Monad.t('b)) => ('b => Monad.t('c)) => 'a => Monad.t('c);
- let flipComposeKleisli: ('b => Monad.t('c)) => ('a => Monad.t('b)) => 'a => Monad.t('c);
- let liftM1: ('a => 'b) => Monad.t('a) => Monad.t('b);
- let when_: Monad.t(bool) => Monad.t(unit) => Monad.t(unit);
- let unless: Monad.t(bool) => Monad.t(unit) => Monad.t(unit);
module Infix: { ... };