package mechaml
Library
Module
Module type
Parameter
Class
Class type
val return : 'a -> 'a m
Wrappers of Lwt's fail functions
val fail : exn -> 'a m
val fail_with : string -> 'a m
Wrappers of Lwt.catch
and Lwt.try_bind
inside this monad
module Infix : sig ... end
The Infix module defines operators for common bind operations
module Syntax : sig ... end
The Syntax module implements the monadic operators provided by OCaml 4.08
module List : sig ... end
The List module wraps the functions of the Lwt_list module inside the Agent monad. Functions suffixed with _s chain the actions sequentially, passing around the updated agent from an action to the next one. The functions suffixed with _m do everything in parallel, using a copy of the initial state in every thread and returning this same original state. The latter can be useful to retrieve a bunch of resources in batch where the updated state is not of interest (e.g download images)
Get the current state of the agent, or set a new one
Wrap the type of functions operating on the agent such as Agent.cookie_jar
or Agent.set_cookie_jar
to be usable inside the monad. For example, the first one go from Agent.t -> Cookiejar.t
to Agent.t -> (Agent.t * Cookiejar.t) Lwt.t
by just returning the agent unmodified together with the current cookie jar and wrap the result through Lwt.return
Note that the redefined functions have the same name as their counterpart, and thus will shadow or can be shadowed by them.
val save_content : string -> string -> unit m
val cookie_jar : Cookiejar.t m
val set_cookie_jar : Cookiejar.t -> unit m
val add_cookie : Cookiejar.Cookie.t -> unit m
val remove_cookie : Cookiejar.Cookie.t -> unit m
val client_headers : Cohttp.Header.t m
val set_client_headers : Cohttp.Header.t -> unit m
val add_client_header : string -> string -> unit m
val remove_client_header : string -> unit m
val set_max_redirect : int -> unit m