sig
  exception Failure
  type 'a t
  exception CoFailure
  type 'a co_t
  val from : (int -> 'a option) -> 'Shtream.t
  val close : 'Shtream.t -> unit
  val of_list : 'a list -> 'Shtream.t
  val list_of : 'Shtream.t -> 'a list
  val of_stream : 'Stream.t -> 'Shtream.t
  val stream_of : 'Shtream.t -> 'Stream.t
  val npeek : ?n:int -> 'Shtream.t -> 'a list
  val peek : ?n:int -> 'Shtream.t -> 'a option
  val empty : 'Shtream.t -> unit
  val is_empty : 'Shtream.t -> bool
  val status : 'Shtream.t -> Proc.status option
  val junk : ?n:int -> 'Shtream.t -> unit
  val next : 'Shtream.t -> 'a
  val next' : 'Shtream.t -> 'a option
  val iter : ('-> unit) -> 'Shtream.t -> unit
  val filter : ('-> bool) -> 'Shtream.t -> 'Shtream.t
  val map : ('-> 'b) -> 'Shtream.t -> 'Shtream.t
  val concat_map : ('-> 'b list) -> 'Shtream.t -> 'Shtream.t
  val fold_left : ('-> '-> 'a) -> '-> 'Shtream.t -> 'a
  val fold_right : ('-> 'Lazy.t -> 'b) -> 'Shtream.t -> '-> 'b
  val nil : unit -> 'Shtream.t
  val insert : '-> 'Shtream.t -> unit
  val cons : '-> 'Shtream.t -> 'Shtream.t
  val append : 'Shtream.t -> 'Shtream.t -> 'Shtream.t
  val try_again : unit -> 'a
  val warn : ('a, unit, string, 'b) Pervasives.format4 -> 'a
  val fail_with : Proc.status -> 'a
  type error_handler = [ `Exception of exn | `Warning of string ] -> unit
  val current_error_handler : Shtream.error_handler Pervasives.ref
  val ignore_errors : Shtream.error_handler
  val warn_on_errors : Shtream.error_handler
  val die_on_errors : Shtream.error_handler
  val die_silently_on_errors : Shtream.error_handler
  val coshtream_of :
    ?procref:Channel.procref -> ('Shtream.t -> 'b) -> 'Shtream.co_t
  val conil : unit -> 'Shtream.co_t
  val conext : 'Shtream.co_t -> '-> unit
  val coclose : 'Shtream.co_t -> unit
  val annihilate : 'Shtream.t -> 'Shtream.co_t -> unit
  val from_low : ?close:(unit -> unit) -> (int -> 'a) -> 'Shtream.t
  val claim : 'Shtream.t -> 'Shtream.t
  val set_reader : 'Shtream.t -> (Pervasives.in_channel -> 'a) -> unit
  val hint_reader : 'Shtream.t -> Reader.t -> unit
  type protector = Util.protector
  val add_protection : Shtream.protector -> 'Shtream.t -> unit
  val add_cleanup : (unit -> unit) -> 'Shtream.t -> unit
  val channel_of :
    ?procref:Channel.procref ->
    ?before:(unit -> unit) ->
    ?after:(unit -> unit) ->
    ('-> unit) -> 'Shtream.t -> Pervasives.in_channel
  val of_channel :
    ?hint:(Reader.raw_line -> 'a) ->
    (Pervasives.in_channel -> 'a) -> Pervasives.in_channel -> 'Shtream.t
  val of_file :
    ?hint:(Reader.raw_line -> 'a) ->
    (Pervasives.in_channel -> 'a) -> string -> 'Shtream.t
  val of_command :
    ?procref:Channel.procref ->
    ?dups:Channel.dup_spec ->
    ?hint:(Reader.raw_line -> 'a) ->
    (Pervasives.in_channel -> 'a) -> string -> 'Shtream.t
  val of_program :
    ?procref:Channel.procref ->
    ?dups:Channel.dup_spec ->
    ?hint:(Reader.raw_line -> 'a) ->
    (Pervasives.in_channel -> 'a) ->
    ?path:bool -> string -> ?argv0:string -> string list -> 'Shtream.t
  val of_thunk :
    ?procref:Channel.procref ->
    ?dups:Channel.dup_spec ->
    ?hint:(Reader.raw_line -> 'a) ->
    (Pervasives.in_channel -> 'a) -> (unit -> unit) -> 'Shtream.t
  module type COMMON =
    sig
      exception Failure
      type 'a t
      exception CoFailure
      type 'a co_t
      val from : (int -> 'a option) -> 'Shtream.COMMON.t
      val close : 'Shtream.COMMON.t -> unit
      val of_list : 'a list -> 'Shtream.COMMON.t
      val list_of : 'Shtream.COMMON.t -> 'a list
      val of_stream : 'Stream.t -> 'Shtream.COMMON.t
      val stream_of : 'Shtream.COMMON.t -> 'Stream.t
      val npeek : ?n:int -> 'Shtream.COMMON.t -> 'a list
      val peek : ?n:int -> 'Shtream.COMMON.t -> 'a option
      val empty : 'Shtream.COMMON.t -> unit
      val is_empty : 'Shtream.COMMON.t -> bool
      val status : 'Shtream.COMMON.t -> Proc.status option
      val junk : ?n:int -> 'Shtream.COMMON.t -> unit
      val next : 'Shtream.COMMON.t -> 'a
      val next' : 'Shtream.COMMON.t -> 'a option
      val iter : ('-> unit) -> 'Shtream.COMMON.t -> unit
      val filter : ('-> bool) -> 'Shtream.COMMON.t -> 'Shtream.COMMON.t
      val map : ('-> 'b) -> 'Shtream.COMMON.t -> 'Shtream.COMMON.t
      val concat_map :
        ('-> 'b list) -> 'Shtream.COMMON.t -> 'Shtream.COMMON.t
      val fold_left : ('-> '-> 'a) -> '-> 'Shtream.COMMON.t -> 'a
      val fold_right :
        ('-> 'Lazy.t -> 'b) -> 'Shtream.COMMON.t -> '-> 'b
      val nil : unit -> 'Shtream.COMMON.t
      val insert : '-> 'Shtream.COMMON.t -> unit
      val cons : '-> 'Shtream.COMMON.t -> 'Shtream.COMMON.t
      val append :
        'Shtream.COMMON.t -> 'Shtream.COMMON.t -> 'Shtream.COMMON.t
      val try_again : unit -> 'a
      val warn : ('a, unit, string, 'b) Pervasives.format4 -> 'a
      val fail_with : Proc.status -> 'a
      type error_handler = [ `Exception of exn | `Warning of string ] -> unit
      val current_error_handler : Shtream.COMMON.error_handler Pervasives.ref
      val ignore_errors : Shtream.COMMON.error_handler
      val warn_on_errors : Shtream.COMMON.error_handler
      val die_on_errors : Shtream.COMMON.error_handler
      val die_silently_on_errors : Shtream.COMMON.error_handler
      val coshtream_of :
        ?procref:Channel.procref ->
        ('Shtream.COMMON.t -> 'b) -> 'Shtream.COMMON.co_t
      val conil : unit -> 'Shtream.COMMON.co_t
      val conext : 'Shtream.COMMON.co_t -> '-> unit
      val coclose : 'Shtream.COMMON.co_t -> unit
      val annihilate : 'Shtream.COMMON.t -> 'Shtream.COMMON.co_t -> unit
      val from_low :
        ?close:(unit -> unit) -> (int -> 'a) -> 'Shtream.COMMON.t
      val claim : 'Shtream.COMMON.t -> 'Shtream.COMMON.t
      val set_reader :
        'Shtream.COMMON.t -> (Pervasives.in_channel -> 'a) -> unit
      val hint_reader : 'Shtream.COMMON.t -> Reader.t -> unit
      type protector = Util.protector
      val add_protection :
        Shtream.COMMON.protector -> 'Shtream.COMMON.t -> unit
      val add_cleanup : (unit -> unit) -> 'Shtream.COMMON.t -> unit
    end
end