Module 3-As_prover.Let_syntax

include Monad_let.Base_syntax2 with type ('a, 'e) t := ( 'a, Env.field ) t
include Core_kernel.Monad.Infix2 with type ('a, 'e) t := ( 'a, Env.field ) t
val (>>=) : ( 'a, Env.field ) t -> ( 'a -> ( 'b, Env.field ) t ) -> ( 'b, Env.field ) t
val (>>|) : ( 'a, Env.field ) t -> ( 'a -> 'b ) -> ( 'b, Env.field ) t
include Monad_let.Let_syntax2 with type ('a, 'e) t := ( 'a, Env.field ) t
val return : 'a -> ( 'a, Env.field ) t
val bind : ( 'a, Env.field ) t -> f:( 'a -> ( 'b, Env.field ) t ) -> ( 'b, Env.field ) t
val map : ( 'a, Env.field ) t -> f:( 'a -> 'b ) -> ( 'b, Env.field ) t
val both : ( 'a, Env.field ) t -> ( 'b, Env.field ) t -> ( 'a * 'b, Env.field ) t
module Open_on_rhs : sig ... end
module Let_syntax : Monad_let.Let_syntax2 with type ('a, 'e) t := ( 'a, Env.field ) t