sig
  type 'a t = 'a option
  type 'a container = 'a t
  val length : 'a container -> int
  val is_empty : 'a container -> bool
  val iter : 'a container -> f:('-> unit) -> unit
  val fold : 'a container -> init:'-> f:('-> '-> 'b) -> 'b
  val exists : 'a container -> f:('-> bool) -> bool
  val for_all : 'a container -> f:('-> bool) -> bool
  val find : 'a container -> f:('-> bool) -> 'a option
  val to_list : 'a container -> 'a list
  val to_array : 'a container -> 'a array
  val container : ('a, 'a container) Container.type_class
  type 'a monad = 'a t
  val ( >>= ) : 'a monad -> ('-> 'b monad) -> 'b monad
  val ( >>| ) : 'a monad -> ('-> 'b) -> 'b monad
  module Monad_infix :
    sig
      type 'a monad = 'a t
      val ( >>= ) : 'a monad -> ('-> 'b monad) -> 'b monad
      val ( >>| ) : 'a monad -> ('-> 'b) -> 'b monad
    end
  val bind : 'a monad -> ('-> 'b monad) -> 'b monad
  val return : '-> 'a monad
  val map : 'a monad -> f:('-> 'b) -> 'b monad
  val join : 'a monad monad -> 'a monad
  val ignore : 'a monad -> unit monad
  type 'a sexpable = 'a t
  val sexp_of_t : ('-> Sexplib.Sexp.t) -> 'a sexpable -> Sexplib.Sexp.t
  val t_of_sexp : (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a sexpable
  val is_none : 'Option.t -> bool
  val is_some : 'Option.t -> bool
  val value_map : 'Option.t -> default:'-> f:('-> 'b) -> 'b
  val map2 : 'Option.t -> 'Option.t -> f:('-> '-> 'c) -> 'Option.t
  val call : '-> f:('-> unit) Option.t -> unit
  val apply : '-> f:('-> 'b) Option.t -> 'Option.t
  val value : 'Option.t -> default:'-> 'a
  val value_exn : 'Option.t -> 'a
  val value_exn_message : string -> 'Option.t -> 'a
  val equal : ('-> '-> bool) -> 'Option.t -> 'Option.t -> bool
  val some : '-> 'Option.t
  val both : 'Option.t -> 'Option.t -> ('a * 'b) Option.t
  val filter : f:('-> bool) -> 'Option.t -> 'Option.t
  val try_with : (unit -> 'a) -> 'Option.t
  val compare : cmp:('-> '-> int) -> 'Option.t -> 'Option.t -> int
end