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