sig
  type 'a t = 'a lazy_t
  val ( >>= ) : 'a t -> ('-> 'b t) -> 'b t
  val ( >>| ) : 'a t -> ('-> 'b) -> 'b t
  module Monad_infix :
    sig
      val ( >>= ) : 'a t -> ('-> 'b t) -> 'b t
      val ( >>| ) : 'a t -> ('-> 'b) -> 'b t
    end
  val bind : 'a t -> ('-> 'b t) -> 'b t
  val return : '-> 'a t
  val map : 'a t -> f:('-> 'b) -> 'b t
  val join : 'a t t -> 'a t
  val ignore : 'a t -> unit t
  val all : 'a t list -> 'a list t
  val all_ignore : unit t list -> unit t
  exception Undefined
  external force : 'Core_lazy.t -> 'a = "%lazy_force"
  val force_val : 'Core_lazy.t -> 'a
  val lazy_from_fun : (unit -> 'a) -> 'Core_lazy.t
  val lazy_from_val : '-> 'Core_lazy.t
  val lazy_is_val : 'Core_lazy.t -> bool
  val t_of_sexp : (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'Core_lazy.t
  val sexp_of_t : ('-> Sexplib.Sexp.t) -> 'Core_lazy.t -> Sexplib.Sexp.t
  val compare : ('-> '-> int) -> 'Core_lazy.t -> 'Core_lazy.t -> int
  val bin_t :
    'Bin_prot.Type_class.t -> 'Core_lazy.t Bin_prot.Type_class.t
  val bin_read_t :
    'Bin_prot.Unsafe_read_c.reader ->
    'Core_lazy.t Bin_prot.Read_ml.reader
  val bin_read_t_ :
    'Bin_prot.Unsafe_read_c.reader ->
    'Core_lazy.t Bin_prot.Unsafe_read_c.reader
  val bin_read_t__ :
    'Bin_prot.Unsafe_read_c.reader ->
    (int -> 'Core_lazy.t) Bin_prot.Unsafe_read_c.reader
  val bin_reader_t :
    'Bin_prot.Type_class.reader ->
    'Core_lazy.t Bin_prot.Type_class.reader
  val bin_size_t :
    'Bin_prot.Size.sizer -> 'Core_lazy.t Bin_prot.Size.sizer
  val bin_write_t :
    'Bin_prot.Unsafe_write_c.writer ->
    'Core_lazy.t Bin_prot.Write_ml.writer
  val bin_write_t_ :
    'Bin_prot.Unsafe_write_c.writer ->
    'Core_lazy.t Bin_prot.Unsafe_write_c.writer
  val bin_writer_t :
    'Bin_prot.Type_class.writer ->
    'Core_lazy.t Bin_prot.Type_class.writer
end