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.Unsafe_read_c.reader -> 'Fqueue.t Bin_prot.Read_ml.reader
  val bin_read_t_ :
    'Bin_prot.Unsafe_read_c.reader ->
    'Fqueue.t Bin_prot.Unsafe_read_c.reader
  val bin_read_t__ :
    'Bin_prot.Unsafe_read_c.reader ->
    (int -> 'Fqueue.t) Bin_prot.Unsafe_read_c.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.Unsafe_write_c.writer -> 'Fqueue.t Bin_prot.Write_ml.writer
  val bin_write_t_ :
    'Bin_prot.Unsafe_write_c.writer ->
    'Fqueue.t Bin_prot.Unsafe_write_c.writer
  val bin_writer_t :
    'Bin_prot.Type_class.writer -> 'Fqueue.t Bin_prot.Type_class.writer
end