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