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