package travesty

  1. Overview
  2. Docs
Legend:
Library
Module
Module type
Parameter
Class
Class type

On_monad implements monadic traversal operators for a given monad M.

Parameters

module M : Base.Monad.S

Signature

include Traversable_types.Basic_generic_on_monad with type 'a t := Outer.Elt.t with type 'a elt := Elt.t with module M := M

Generic 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 Generic_types.Generic with type 'a t := Outer.Elt.t with type 'a elt := Elt.t
val map_m : Outer.Elt.t -> f:(Elt.t -> Elt.t M.t) -> Outer.Elt.t M.t

map_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 ~f
val fold_map_m : Outer.Elt.t -> f:('acc -> Elt.t -> ('acc * Elt.t) M.t) -> init:'acc -> ('acc * Outer.Elt.t) M.t

fold_map_m c ~f ~init folds f monadically over every t in c, threading through an accumulator with initial value init.

val fold_m : Outer.Elt.t -> init:'acc -> f:('acc -> Elt.t -> 'acc M.t) -> 'acc M.t

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.

val iter_m : Outer.Elt.t -> f:(Elt.t -> Base.unit M.t) -> Base.unit M.t

iter_m x ~f iterates the monadic computation f over x, returning the final monadic effect.

val mapi_m : f:(Base.int -> Elt.t -> Elt.t M.t) -> Outer.Elt.t -> Outer.Elt.t M.t

mapi_m ~f x behaves as mapM, but also supplies f with the index of the element. This index should match the actual position of the element in the container x.

OCaml

Innovation. Community. Security.