Option.On_monadSourceOn_monad implements monadic folding and mapping operators for a given monad M, including arity-1 specific operators.
module M : Base.Monad.Sinclude Travesty.Traversable.Generic_on_monad
with type 'a t := 'a t
and type 'a elt := 'a
with module M := Minclude Travesty.Traversable.Basic_generic_on_monad
with type 'a t := 'a t
with type 'a elt := 'a
with module M := MGeneric refers to the container type as 'a t, and the element type as 'a elt; substitute t/elt (arity-0) or 'a t/'a (arity-1) accordingly below.
include Travesty.Types_intf.Generic
with type 'a t := 'a t
with type 'a elt := 'amap_m c ~f maps f over every t in c, threading through monadic state.
Example:
(* Travesty_base_exts.List adds monadic traversals to a list;
With_errors (in S1_container) implements them on the On_error
monad. *)
let f x =
Or_error.(if 0 < x then error_string "negative!" else ok x)
in
List.With_errors.map_m integers ~ffold_map_m c ~f ~init folds f monadically over every t in c, threading through an accumulator with initial value init.
fold_m x ~init ~f folds the monadic computation f over x, starting with initial value init, and returning the final value inside the monadic effect.
iter_m x ~f iterates the monadic computation f over x, returning the final monadic effect.