sig
  type 'a llist = Nil | Cons of 'a * 'Llist.llist Lazy.t
  val hd : 'Llist.llist -> 'a
  val tl : 'Llist.llist -> 'Llist.llist
  val take : int -> 'Llist.llist -> 'a list
  val map : ('-> 'b) -> 'Llist.llist -> 'Llist.llist
  val repeat : '-> 'Llist.llist
  val app : 'Llist.llist -> 'Llist.llist -> 'Llist.llist
  val combine : 'Llist.llist -> 'Llist.llist -> ('a * 'b) Llist.llist
  val filter : ('-> bool) -> 'Llist.llist -> 'Llist.llist
  val concat : 'Llist.llist Llist.llist -> 'Llist.llist
  val unfoldr : ('-> ('a * 'b) option) -> '-> 'Llist.llist
  val continually : (unit -> 'a) -> 'Llist.llist
  val from : int -> int Llist.llist
  val of_stream : 'Stream.t -> 'Llist.llist
  val sllist :
    ?items:int -> string -> ('-> string) -> 'Llist.llist -> string
  val of_string : string -> char Llist.llist
end