sig
  module type QUEUE =
    sig
      type 'a t
      exception Empty
      val create : unit -> 'ExtSQueue.QUEUE.t
      val add : '-> 'ExtSQueue.QUEUE.t -> unit
      val push : '-> 'ExtSQueue.QUEUE.t -> unit
      val take : 'ExtSQueue.QUEUE.t -> 'a
      val pop : 'ExtSQueue.QUEUE.t -> 'a
      val peek : 'ExtSQueue.QUEUE.t -> 'a
      val top : 'ExtSQueue.QUEUE.t -> 'a
      val clear : 'ExtSQueue.QUEUE.t -> unit
      val copy : 'ExtSQueue.QUEUE.t -> 'ExtSQueue.QUEUE.t
      val is_empty : 'ExtSQueue.QUEUE.t -> bool
      val length : 'ExtSQueue.QUEUE.t -> int
      val iter : ('-> unit) -> 'ExtSQueue.QUEUE.t -> unit
      val fold : ('-> '-> 'a) -> '-> 'ExtSQueue.QUEUE.t -> 'a
      val transfer : 'ExtSQueue.QUEUE.t -> 'ExtSQueue.QUEUE.t -> unit
    end
  module Queue :
    sig
      type 'a t
      exception Empty
      val create : unit -> 'a t
      val add : '-> 'a t -> unit
      val push : '-> 'a t -> unit
      val take : 'a t -> 'a
      val pop : 'a t -> 'a
      val peek : 'a t -> 'a
      val top : 'a t -> 'a
      val clear : 'a t -> unit
      val copy : 'a t -> 'a t
      val is_empty : 'a t -> bool
      val length : 'a t -> int
      val iter : ('-> unit) -> 'a t -> unit
      val fold : ('-> '-> 'a) -> '-> 'b t -> 'a
      val transfer : 'a t -> 'a t -> unit
      val string_of : ('-> string) -> 'a t -> string
    end
end