sig
  type 'a enumerable = 'Stream.t
  val enum : 'a enumerable -> 'BatEnum.t
  val of_enum : 'BatEnum.t -> 'a enumerable
  type 'a mappable = 'Stream.t
  val map : ('-> 'b) -> 'a mappable -> 'b mappable
  val enum : 'Stream.t -> 'BatEnum.t
  val of_enum : 'BatEnum.t -> 'Stream.t
  val of_input : BatIO.input -> char Stream.t
  val on_output : 'BatIO.output -> char Stream.t -> unit
  val of_fun : (unit -> 'a) -> 'Stream.t
  val foldl : ('-> '-> 'a * bool option) -> '-> 'Stream.t -> 'a
  val foldr : ('-> 'b lazy_t -> 'b) -> '-> 'Stream.t -> 'b
  val fold : ('-> '-> 'a * bool option) -> 'Stream.t -> 'a
  val filter : ('-> bool) -> 'Stream.t -> 'Stream.t
  val map : ('-> 'b) -> 'Stream.t -> 'Stream.t
  val map2 : ('-> '-> 'c) -> 'Stream.t -> 'Stream.t -> 'Stream.t
  val scanl : ('-> '-> 'a) -> '-> 'Stream.t -> 'Stream.t
  val scan : ('-> '-> 'a) -> 'Stream.t -> 'Stream.t
  val concat : 'Stream.t Stream.t -> 'Stream.t
  val take : int -> 'Stream.t -> 'Stream.t
  val drop : int -> 'Stream.t -> 'Stream.t
  val take_while : ('-> bool) -> 'Stream.t -> 'Stream.t
  val drop_while : ('-> bool) -> 'Stream.t -> 'Stream.t
  val dup : 'Stream.t -> 'Stream.t * 'Stream.t
  val comb : 'Stream.t * 'Stream.t -> ('a * 'b) Stream.t
  val split : ('a * 'b) Stream.t -> 'Stream.t * 'Stream.t
  val merge :
    (bool -> '-> bool) -> 'Stream.t * 'Stream.t -> 'Stream.t
  val switch : ('-> bool) -> 'Stream.t -> 'Stream.t * 'Stream.t
  val cons : '-> 'Stream.t -> 'Stream.t
  val apnd : 'Stream.t -> 'Stream.t -> 'Stream.t
  val is_empty : 'Stream.t -> bool
  val next : 'Stream.t -> 'a
  module StreamLabels :
    sig
      val iter : f:('-> unit) -> 'Stream.t -> unit
      val foldl :
        f:('-> '-> 'a * bool option) -> init:'-> 'Stream.t -> 'a
      val foldr : f:('-> 'b lazy_t -> 'b) -> init:'-> 'Stream.t -> 'b
      val fold : f:('-> '-> 'a * bool option) -> init:'Stream.t -> 'a
      val filter : f:('-> bool) -> 'Stream.t -> 'Stream.t
      val map : f:('-> 'b) -> 'Stream.t -> 'Stream.t
      val map2 :
        f:('-> '-> 'c) -> 'Stream.t -> 'Stream.t -> 'Stream.t
      val scanl : f:('-> '-> 'a) -> '-> 'Stream.t -> 'Stream.t
      val scan : f:('-> '-> 'a) -> 'Stream.t -> 'Stream.t
      val take_while : f:('-> bool) -> 'Stream.t -> 'Stream.t
      val drop_while : f:('-> bool) -> 'Stream.t -> 'Stream.t
      val merge :
        f:(bool -> '-> bool) -> 'Stream.t * 'Stream.t -> 'Stream.t
      val switch : f:('-> bool) -> 'Stream.t -> 'Stream.t * 'Stream.t
    end
end