sig
  exception Empty
  type 'a t
  val test_invariants : 'Fqueue.t -> unit
  val empty : 'Fqueue.t
  val enqueue : 'Fqueue.t -> '-> 'Fqueue.t
  val enqueue_top : 'Fqueue.t -> '-> 'Fqueue.t
  val bot_exn : 'Fqueue.t -> 'a
  val bot : 'Fqueue.t -> 'a option
  val top_exn : 'Fqueue.t -> 'a
  val top : 'Fqueue.t -> 'a option
  val dequeue_exn : 'Fqueue.t -> 'a * 'Fqueue.t
  val dequeue : 'Fqueue.t -> ('a * 'Fqueue.t) option
  val discard_exn : 'Fqueue.t -> 'Fqueue.t
  val to_list : 'Fqueue.t -> 'a list
  val length : 'Fqueue.t -> int
  val is_empty : 'Fqueue.t -> bool
  val compare : ('-> '-> int) -> 'Fqueue.t -> 'Fqueue.t -> int
  val t_of_sexp : (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'Fqueue.t
  val sexp_of_t : ('-> Sexplib.Sexp.t) -> 'Fqueue.t -> Sexplib.Sexp.t
  val bin_t : 'Bin_prot.Type_class.t -> 'Fqueue.t Bin_prot.Type_class.t
  val bin_read_t :
    'Bin_prot.Read.reader -> 'Fqueue.t Bin_prot.Read.reader
  val __bin_read_t__ :
    'Bin_prot.Read.reader -> (int -> 'Fqueue.t) Bin_prot.Read.reader
  val bin_reader_t :
    'Bin_prot.Type_class.reader -> 'Fqueue.t Bin_prot.Type_class.reader
  val bin_size_t : 'Bin_prot.Size.sizer -> 'Fqueue.t Bin_prot.Size.sizer
  val bin_write_t :
    'Bin_prot.Write.writer -> 'Fqueue.t Bin_prot.Write.writer
  val bin_writer_t :
    'Bin_prot.Type_class.writer -> 'Fqueue.t Bin_prot.Type_class.writer
end