sig
  type 'a t
  val from : (unit -> 'a option Lwt.t) -> 'Lwt_stream.t
  val of_list : 'a list -> 'Lwt_stream.t
  val of_string : string -> char Lwt_stream.t
  val clone : 'Lwt_stream.t -> 'Lwt_stream.t
  exception Empty
  val peek : 'Lwt_stream.t -> 'a option Lwt.t
  val npeek : int -> 'Lwt_stream.t -> 'a list Lwt.t
  val get : 'Lwt_stream.t -> 'a option Lwt.t
  val nget : int -> 'Lwt_stream.t -> 'a list Lwt.t
  val get_while : ('-> bool) -> 'Lwt_stream.t -> 'a list Lwt.t
  val get_while_s : ('-> bool Lwt.t) -> 'Lwt_stream.t -> 'a list Lwt.t
  val next : 'Lwt_stream.t -> 'Lwt.t
  val junk : 'Lwt_stream.t -> unit Lwt.t
  val njunk : int -> 'Lwt_stream.t -> unit Lwt.t
  val junk_while : ('-> bool) -> 'Lwt_stream.t -> unit Lwt.t
  val junk_while_s : ('-> bool Lwt.t) -> 'Lwt_stream.t -> unit Lwt.t
  val junk_old : 'Lwt_stream.t -> unit Lwt.t
  val is_empty : 'Lwt_stream.t -> bool Lwt.t
  val choose : 'Lwt_stream.t list -> 'Lwt_stream.t
  val map : ('-> 'b) -> 'Lwt_stream.t -> 'Lwt_stream.t
  val map_s : ('-> 'Lwt.t) -> 'Lwt_stream.t -> 'Lwt_stream.t
  val filter : ('-> bool) -> 'Lwt_stream.t -> 'Lwt_stream.t
  val filter_s : ('-> bool Lwt.t) -> 'Lwt_stream.t -> 'Lwt_stream.t
  val filter_map : ('-> 'b option) -> 'Lwt_stream.t -> 'Lwt_stream.t
  val filter_map_s :
    ('-> 'b option Lwt.t) -> 'Lwt_stream.t -> 'Lwt_stream.t
  val fold : ('-> '-> 'b) -> 'Lwt_stream.t -> '-> 'Lwt.t
  val fold_s : ('-> '-> 'Lwt.t) -> 'Lwt_stream.t -> '-> 'Lwt.t
  val iter : ('-> unit) -> 'Lwt_stream.t -> unit Lwt.t
  val iter_p : ('-> unit Lwt.t) -> 'Lwt_stream.t -> unit Lwt.t
  val iter_s : ('-> unit Lwt.t) -> 'Lwt_stream.t -> unit Lwt.t
  val find : ('-> bool) -> 'Lwt_stream.t -> 'a option Lwt.t
  val find_s : ('-> bool Lwt.t) -> 'Lwt_stream.t -> 'a option Lwt.t
  val find_map : ('-> 'b option) -> 'Lwt_stream.t -> 'b option Lwt.t
  val find_map_s :
    ('-> 'b option Lwt.t) -> 'Lwt_stream.t -> 'b option Lwt.t
  val combine : 'Lwt_stream.t -> 'Lwt_stream.t -> ('a * 'b) Lwt_stream.t
  val append : 'Lwt_stream.t -> 'Lwt_stream.t -> 'Lwt_stream.t
  val concat : 'Lwt_stream.t Lwt_stream.t -> 'Lwt_stream.t
  val parse : 'Lwt_stream.t -> ('Lwt_stream.t -> 'Lwt.t) -> 'Lwt.t
  val hexdump : char Lwt_stream.t -> string Lwt_stream.t
  type 'a node = Cons of 'a * 'Lwt_stream.lazy_list | Nil
  and 'a lazy_list = 'Lwt_stream.node Lwt.t Lazy.t
  val of_lazy_list : 'Lwt_stream.lazy_list -> 'Lwt_stream.t
  val to_lazy_list : 'Lwt_stream.t -> 'Lwt_stream.lazy_list
end