sig
  type 'a node_t
  type 'a t = 'BatDllist.node_t
  type 'a mappable = 'a t
  type 'a enumerable = 'a t
  exception Empty
  val create : '-> 'BatDllist.node_t
  val copy : 'BatDllist.node_t -> 'BatDllist.node_t
  val length : 'BatDllist.node_t -> int
  val rev : 'BatDllist.node_t -> unit
  val add : 'BatDllist.node_t -> '-> unit
  val append : 'BatDllist.node_t -> '-> 'BatDllist.node_t
  val prepend : 'BatDllist.node_t -> '-> 'BatDllist.node_t
  val promote : 'BatDllist.node_t -> unit
  val demote : 'BatDllist.node_t -> unit
  val remove : 'BatDllist.node_t -> unit
  val drop : 'BatDllist.node_t -> 'BatDllist.node_t
  val rev_drop : 'BatDllist.node_t -> 'BatDllist.node_t
  val splice : 'BatDllist.node_t -> 'BatDllist.node_t -> unit
  val get : 'BatDllist.node_t -> 'a
  val set : 'BatDllist.node_t -> '-> unit
  val next : 'BatDllist.node_t -> 'BatDllist.node_t
  val prev : 'BatDllist.node_t -> 'BatDllist.node_t
  val skip : 'BatDllist.node_t -> int -> 'BatDllist.node_t
  val iter : ('-> unit) -> 'BatDllist.node_t -> unit
  val fold_left : ('-> '-> 'a) -> '-> 'BatDllist.node_t -> 'a
  val fold_right : ('-> '-> 'b) -> 'BatDllist.node_t -> '-> 'b
  val find : ('-> bool) -> 'BatDllist.node_t -> 'BatDllist.node_t
  val for_all : ('-> bool) -> 'BatDllist.node_t -> bool
  val exists : ('-> bool) -> 'BatDllist.node_t -> bool
  val map : ('-> 'b) -> 'BatDllist.node_t -> 'BatDllist.node_t
  val filter : ('-> bool) -> 'BatDllist.node_t -> 'BatDllist.node_t
  val filter_map :
    ('-> 'b option) -> 'BatDllist.node_t -> 'BatDllist.node_t
  val to_list : 'BatDllist.node_t -> 'a list
  val of_list : 'a list -> 'BatDllist.node_t
  val enum : 'BatDllist.node_t -> 'BatEnum.t
  val rev_enum : 'BatDllist.node_t -> 'BatEnum.t
  val backwards : 'BatDllist.node_t -> 'BatEnum.t
  val of_enum : 'BatEnum.t -> 'BatDllist.node_t
  val print :
    ?first:string ->
    ?last:string ->
    ?sep:string ->
    ('BatInnerIO.output -> '-> unit) ->
    'BatInnerIO.output -> 'BatDllist.t -> unit
  val invariants : 'BatDllist.t -> unit
end