sig
  type 'a t = 'LazyList.node Lazy.t
  and 'a node = Nil | Cons of 'a * 'LazyList.t
  val nil : 'LazyList.t
  val cons : '-> 'LazyList.t -> 'LazyList.t
  val next : 'LazyList.t -> 'LazyList.node
  val tl : 'LazyList.t -> 'LazyList.t
  val hd : 'LazyList.t -> 'a
  val one : '-> 'LazyList.t
  val filter : ('-> bool) -> 'LazyList.t -> 'LazyList.t
  val flatten : 'LazyList.t list -> 'LazyList.t
  val map : ('-> 'b) -> 'LazyList.t -> 'LazyList.t
  val concat : 'LazyList.t LazyList.t -> 'LazyList.t
  val iter : ('-> unit) -> 'LazyList.t -> unit
  val find : ('-> bool) -> 'LazyList.t -> 'a
  val exists : ('-> bool) -> 'LazyList.t -> bool
end