Free_monad.Over_applicativemodule F : Preface_specs.APPLICATIVEtype 'a f = 'a F.tThe type held by the Preface_specs.Functor.
A Free monad is also a Preface_specs.Functor.
module Functor : Preface_specs.Functor.API with type 'a t = 'a tA Free monad is also an Preface_specs.Applicative.
module Applicative : Preface_specs.Applicative.API with type 'a t = 'a tA Free monad is also (obviously) a Preface_specs.Monad.
module Monad : Preface_specs.Monad.API with type 'a t = 'a tjoin remove one level of monadic structure, projecting its bound argument into the outer level.
val return : 'a -> 'a tCreate a new 'a t.
Composing monadic functions using Kleisli Arrow (from left to right).
Composing monadic functions using Kleisli Arrow (from right to left).
Mapping over from 'a and 'b to 'c over 'a t and 'b t to 'c t.
Mapping over from 'a and 'b and 'c to 'd over 'a t and 'b t and 'c t to 'd t.
Create a new 'a t, replacing all values in the 'b t by given a value of 'a.
module Infix : Preface_specs.Monad.INFIX with type 'a t := 'a tInfix version of OPERATION.compose_right_to_left.
Sequentially compose two actions, discarding any value produced by the first.
Sequentially compose two actions, discarding any value produced by the second.
Infix version of Preface_specs.Functor.CORE.map.
Flipped and infix version of Preface_specs.Functor.CORE.map.
Infix version of Preface_specs.Functor.OPERATION.replace.
Flipped and infix version of Preface_specs.Functor.OPERATION.replace.
module Syntax : Preface_specs.Monad.SYNTAX with type 'a t := 'a tSyntaxic shortcuts for flipped version of CORE.bind:
let* x = e in f is equals to bind (fun x -> f) e.