sig
type 'a node_t = 'a Extlib.Dllist.node_t
type 'a t = 'a node_t
type 'a mappable = 'a t
val map : ('a -> 'b) -> 'a mappable -> 'b mappable
type 'a enumerable = 'a t
val enum : 'a enumerable -> 'a Extlib.Enum.t
val of_enum : 'a Extlib.Enum.t -> 'a enumerable
exception Empty
val create : 'a -> 'a node_t
val copy : 'a node_t -> 'a node_t
val length : 'a node_t -> int
val rev : 'a node_t -> unit
val add : 'a node_t -> 'a -> unit
val append : 'a node_t -> 'a -> 'a node_t
val prepend : 'a node_t -> 'a -> 'a node_t
val promote : 'a node_t -> unit
val demote : 'a node_t -> unit
val remove : 'a node_t -> unit
val drop : 'a node_t -> 'a node_t
val rev_drop : 'a node_t -> 'a node_t
val splice : 'a node_t -> 'a node_t -> unit
val get : 'a node_t -> 'a
val set : 'a node_t -> 'a -> unit
val next : 'a node_t -> 'a node_t
val prev : 'a node_t -> 'a node_t
val skip : 'a node_t -> int -> 'a node_t
val iter : ('a -> unit) -> 'a node_t -> unit
val fold_left : ('a -> 'b -> 'a) -> 'a -> 'b node_t -> 'a
val fold_right : ('a -> 'b -> 'b) -> 'a node_t -> 'b -> 'b
val map : ('a -> 'b) -> 'a node_t -> 'b node_t
val filter : ('a -> bool) -> 'a node_t -> 'a node_t
val filter_map : ('a -> 'b option) -> 'a node_t -> 'b node_t
val to_list : 'a node_t -> 'a list
val of_list : 'a list -> 'a node_t
val enum : 'a node_t -> 'a Extlib.Enum.t
val rev_enum : 'a node_t -> 'a Extlib.Enum.t
val of_enum : 'a Extlib.Enum.t -> 'a node_t
val t_of_sexp : (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a t
val sexp_of_t : ('a -> Sexplib.Sexp.t) -> 'a t -> Sexplib.Sexp.t
val print :
?first:string ->
?last:string ->
?sep:string ->
('a Extlib.InnerIO.output -> 'b -> unit) ->
'a Extlib.InnerIO.output -> 'b t -> unit
end