Module Base__.Lazy
val compare : ('a -> 'a -> int) -> 'a t -> 'a t -> intval hash_fold_t : (Base.Hash.state -> 'a -> Base.Hash.state) -> Base.Hash.state -> 'a t -> Base.Hash.state
include Base.Sexpable.S1 with type 'a t := 'a t
val t_of_sexp : (Base.Sexp.t -> 'a) -> Base.Sexp.t -> 'a tval sexp_of_t : ('a -> Base.Sexp.t) -> 'a t -> Base.Sexp.t
include Base.Monad.S with type 'a t := 'a t
include Base__.Monad_intf.Syntax with type 'a t := 'a t
module Let_syntax : sig ... endinclude Base__.Monad_intf.S_without_syntax with type 'a t := 'a t
val all_unit : 'a t list -> 'a tLike
all, but ensures that every monadic value in the list produces a unit value, all of which are discarded rather than being collected into a list.
val all : 'a t list -> 'a tval ignore_m : 'a t -> 'a tignore_m tismap t ~f:(fun _ -> ()).ignore_mused to be calledignore, but we decided that was a bad name, because it shadowed the widely usedCaml.ignore. Some monads still dolet ignore = ignore_mfor historical reasons.
val return : 'a -> 'a treturn vreturns the (trivial) computation that returns v.
module Monad_infix : sig ... endval force : 'a t -> 'aforce xforces the suspensionxand returns its result. Ifxhas already been forced,Lazy.force xreturns the same value again without recomputing it. If it raised an exception, the same exception is raised again. RaiseUndefinedif the forcing ofxtries to forcexitself recursively.
val force_val : 'a t -> 'aLike
forceexcept thatforce_val xdoes not use an exception handler, so it may be more efficient. However, if the computation ofxraises an exception, it is unspecified whetherforce_val xraises the same exception orUndefined.
val from_fun : (unit -> 'a) -> 'a tfrom_fun fis the same aslazy (f ())but slightly more efficient iffis a variable.from_funshould only be used if the functionfis already defined. In particular it is always less efficient to writefrom_fun (fun () -> expr)thanlazy expr.
val from_val : 'a -> 'a tfrom_val vreturns an already-forced suspension ofv(wherevcan be any expression). Essentially,from_val expris the same aslet var = expr in lazy var.
val is_val : 'a t -> boolis_val xreturnstrueifxhas already been forced and did not raise an exception.
module T_unforcing : sig ... endThis type offers a serialization function
sexp_of_tthat won't force its argument. Instead, it will serialize the'aif it is available, or just use a custom string indicating it is not forced. Note that this is not a round-trippable type, thus the type does not exposeof_sexp. To be used in debug code, while tracking a Heisenbug, etc.