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