sig
  type +'a dq
  type 'a t = 'BatDeque.dq
  type 'a enumerable = 'a t
  type 'a mappable = 'a t
  val size : 'BatDeque.dq -> int
  val empty : 'BatDeque.dq
  val cons : '-> 'BatDeque.dq -> 'BatDeque.dq
  val snoc : 'BatDeque.dq -> '-> 'BatDeque.dq
  val front : 'BatDeque.dq -> ('a * 'BatDeque.dq) option
  val rear : 'BatDeque.dq -> ('BatDeque.dq * 'a) option
  val eq : ?eq:('-> '-> bool) -> 'BatDeque.dq -> 'BatDeque.dq -> bool
  val rev : 'BatDeque.dq -> 'BatDeque.dq
  val is_empty : 'BatDeque.dq -> bool
  val at : ?backwards:bool -> 'BatDeque.dq -> int -> 'a option
  val map : ('-> 'b) -> 'BatDeque.dq -> 'BatDeque.dq
  val mapi : (int -> '-> 'b) -> 'BatDeque.dq -> 'BatDeque.dq
  val iter : ('-> unit) -> 'BatDeque.dq -> unit
  val iteri : (int -> '-> unit) -> 'BatDeque.dq -> unit
  val find :
    ?backwards:bool -> ('-> bool) -> 'BatDeque.dq -> (int * 'a) option
  val fold_left : ('acc -> '-> 'acc) -> 'acc -> 'BatDeque.dq -> 'acc
  val fold_right : ('-> 'acc -> 'acc) -> 'BatDeque.dq -> 'acc -> 'acc
  val append : 'BatDeque.dq -> 'BatDeque.dq -> 'BatDeque.dq
  val append_list : 'BatDeque.dq -> 'a list -> 'BatDeque.dq
  val prepend_list : 'a list -> 'BatDeque.dq -> 'BatDeque.dq
  val rotate_forward : 'BatDeque.dq -> 'BatDeque.dq
  val rotate_backward : 'BatDeque.dq -> 'BatDeque.dq
  val of_list : 'a list -> 'BatDeque.dq
  val to_list : 'BatDeque.dq -> 'a list
  val of_enum : 'BatEnum.t -> 'BatDeque.dq
  val enum : 'BatDeque.dq -> 'BatEnum.t
  val print :
    ?first:string ->
    ?last:string ->
    ?sep:string ->
    ('a, 'b) BatIO.printer -> ('BatDeque.dq, 'b) BatIO.printer
  val invariants : 'BatDeque.t -> unit
end