sig
  module Stream :
    sig
      type 'a t = 'Stream.t
      type 'a stored
      val singleton : '-> 'a t
      val map : ('-> 'b) -> 'a t -> 'b t
      val expand : ('-> 'b t) -> 'a t -> 'b t
      val iter : ('-> unit) -> 'a t -> unit
      val fold : ('-> '-> 'b) -> '-> 'a t -> 'b
      val of_list : 'a list -> 'a stored
      val to_list : 'a t -> 'a list
      val empty : 'a stored
      val store : 'a t -> 'a stored
      val gennew : 'a stored -> 'a t
    end
  module Seq :
    sig
      type 'a t = 'BatSeq.t
      type 'a stored = 'BatSeq.t
      val singleton : '-> 'a t
      val map : ('-> 'b) -> 'a t -> 'b t
      val expand : ('-> 'b t) -> 'a t -> 'b t
      val iter : ('-> unit) -> 'a t -> unit
      val fold : ('-> '-> 'b) -> '-> 'a t -> 'b
      val of_list : 'a list -> 'a stored
      val to_list : 'a t -> 'a list
      val empty : 'a stored
      val store : 'a t -> 'a stored
      val gennew : 'a stored -> 'a t
    end
  module Enum :
    sig
      type 'a t = 'BatEnum.t
      type 'a stored
      val singleton : '-> 'a t
      val map : ('-> 'b) -> 'a t -> 'b t
      val expand : ('-> 'b t) -> 'a t -> 'b t
      val iter : ('-> unit) -> 'a t -> unit
      val fold : ('-> '-> 'b) -> '-> 'a t -> 'b
      val of_list : 'a list -> 'a stored
      val to_list : 'a t -> 'a list
      val empty : 'a stored
      val store : 'a t -> 'a stored
      val gennew : 'a stored -> 'a t
    end
  module LazyList :
    sig
      type 'a t = 'BatLazyList.t
      type 'a stored = 'BatLazyList.t
      val singleton : '-> 'a t
      val map : ('-> 'b) -> 'a t -> 'b t
      val expand : ('-> 'b t) -> 'a t -> 'b t
      val iter : ('-> unit) -> 'a t -> unit
      val fold : ('-> '-> 'b) -> '-> 'a t -> 'b
      val of_list : 'a list -> 'a stored
      val to_list : 'a t -> 'a list
      val empty : 'a stored
      val store : 'a t -> 'a stored
      val gennew : 'a stored -> 'a t
    end
end