sig
  type filename = string
  type rel
  type abs
  type t
  val root : As_path.t
  val empty : As_path.t
  val dash : As_path.t
  val add : As_path.t -> string -> As_path.t
  val concat : As_path.t -> As_path.rel -> As_path.t
  val ( / ) : As_path.t -> string -> As_path.t
  val ( // ) : As_path.t -> As_path.rel -> As_path.t
  val file : As_path.filename -> As_path.t
  val base : string -> As_path.t
  val basename : As_path.t -> string
  val dirname : As_path.t -> As_path.t
  val rem_prefix : As_path.t -> As_path.t -> As_path.rel option
  val find_prefix : As_path.t -> As_path.t -> As_path.t option
  val is_root : As_path.t -> bool
  val is_empty : As_path.t -> bool
  val is_dash : As_path.t -> bool
  val is_rel : As_path.t -> bool
  val is_abs : As_path.t -> bool
  val is_prefix : As_path.t -> As_path.t -> bool
  val equal : As_path.t -> As_path.t -> bool
  val compare : As_path.t -> As_path.t -> int
  val to_rel : As_path.t -> As_path.rel option
  val of_rel : As_path.rel -> As_path.t
  val to_abs : As_path.t -> As_path.abs option
  val of_abs : As_path.abs -> As_path.t
  val to_segs : As_path.t -> [ `Abs of string list | `Rel of string list ]
  val of_segs : [ `Abs of string list | `Rel of string list ] -> As_path.t
  val to_string : As_path.t -> string
  val of_string : string -> As_path.t
  val quote : As_path.t -> string
  val pp : Format.formatter -> As_path.t -> unit
  type ext =
      [ `A
      | `Byte
      | `C
      | `Cma
      | `Cmi
      | `Cmo
      | `Cmt
      | `Cmti
      | `Cmx
      | `Cmxa
      | `Cmxs
      | `Css
      | `Dll
      | `Exe
      | `Ext of string
      | `Gif
      | `H
      | `Html
      | `Img
      | `Install
      | `Jpeg
      | `Js
      | `Json
      | `Lib
      | `Md
      | `Ml
      | `Ml_dep
      | `Ml_pp
      | `Mli
      | `Mli_dep
      | `Mli_pp
      | `Native
      | `O
      | `Opt
      | `Png
      | `Sh
      | `So
      | `Tar
      | `Tbz
      | `Xml
      | `Zip ]
  val ext_to_string : As_path.ext -> string
  val ext_of_string : string -> As_path.ext
  val pp_ext : Format.formatter -> As_path.ext -> unit
  val ext : As_path.t -> As_path.ext option
  val get_ext : As_path.t -> As_path.ext
  val add_ext : As_path.t -> As_path.ext -> As_path.t
  val rem_ext : As_path.t -> As_path.t
  val change_ext : As_path.t -> As_path.ext -> As_path.t
  val ( + ) : As_path.t -> As_path.ext -> As_path.t
  val has_ext : As_path.ext -> As_path.t -> bool
  val ext_matches : As_path.ext list -> As_path.t -> bool
  module Rel :
    sig
      type path = As_path.t
      type t = As_path.rel
      val empty : As_path.rel
      val dash : As_path.rel
      val add : As_path.rel -> string -> As_path.rel
      val concat : As_path.rel -> As_path.rel -> As_path.rel
      val file : As_path.filename -> As_path.rel
      val base : string -> As_path.rel
      val ( / ) : As_path.rel -> string -> As_path.rel
      val ( // ) : As_path.rel -> As_path.rel -> As_path.rel
      val basename : As_path.rel -> string
      val dirname : As_path.rel -> As_path.rel
      val rem_prefix : As_path.rel -> As_path.rel -> As_path.rel option
      val find_prefix : As_path.rel -> As_path.rel -> As_path.rel
      val is_empty : As_path.rel -> bool
      val is_dash : As_path.rel -> bool
      val is_prefix : As_path.rel -> As_path.rel -> bool
      val equal : As_path.rel -> As_path.rel -> bool
      val compare : As_path.rel -> As_path.rel -> int
      val to_segs : As_path.rel -> string list
      val of_segs : string list -> As_path.rel
      val to_string : As_path.rel -> string
      val quote : As_path.rel -> string
      val pp : Format.formatter -> As_path.rel -> unit
      val ext : As_path.rel -> As_path.ext option
      val get_ext : As_path.rel -> As_path.ext
      val add_ext : As_path.rel -> As_path.ext -> As_path.rel
      val rem_ext : As_path.rel -> As_path.rel
      val change_ext : As_path.rel -> As_path.ext -> As_path.rel
      val ( + ) : As_path.rel -> As_path.ext -> As_path.rel
      val has_ext : As_path.ext -> As_path.rel -> bool
      val ext_matches : As_path.ext list -> As_path.rel -> bool
      module Set :
        sig
          type elt = rel
          type t
          val empty : t
          val is_empty : t -> bool
          val mem : elt -> t -> bool
          val add : elt -> t -> t
          val singleton : elt -> t
          val remove : elt -> t -> t
          val union : t -> t -> t
          val inter : t -> t -> t
          val diff : t -> t -> t
          val compare : t -> t -> int
          val equal : t -> t -> bool
          val subset : t -> t -> bool
          val iter : (elt -> unit) -> t -> unit
          val fold : (elt -> '-> 'a) -> t -> '-> 'a
          val for_all : (elt -> bool) -> t -> bool
          val exists : (elt -> bool) -> t -> bool
          val filter : (elt -> bool) -> t -> t
          val partition : (elt -> bool) -> t -> t * t
          val cardinal : t -> int
          val elements : t -> elt list
          val min_elt : t -> elt
          val max_elt : t -> elt
          val choose : t -> elt
          val split : elt -> t -> t * bool * t
          val find : elt -> t -> elt
          val of_list : elt list -> As_path.Rel.t
        end
      module Map :
        sig
          type key = rel
          type +'a t
          val empty : 'a t
          val is_empty : 'a t -> bool
          val mem : key -> 'a t -> bool
          val add : key -> '-> 'a t -> 'a t
          val singleton : key -> '-> 'a t
          val remove : key -> 'a t -> 'a t
          val merge :
            (key -> 'a option -> 'b option -> 'c option) ->
            'a t -> 'b t -> 'c t
          val compare : ('-> '-> int) -> 'a t -> 'a t -> int
          val equal : ('-> '-> bool) -> 'a t -> 'a t -> bool
          val iter : (key -> '-> unit) -> 'a t -> unit
          val fold : (key -> '-> '-> 'b) -> 'a t -> '-> 'b
          val for_all : (key -> '-> bool) -> 'a t -> bool
          val exists : (key -> '-> bool) -> 'a t -> bool
          val filter : (key -> '-> bool) -> 'a t -> 'a t
          val partition : (key -> '-> bool) -> 'a t -> 'a t * 'a t
          val cardinal : 'a t -> int
          val bindings : 'a t -> (key * 'a) list
          val min_binding : 'a t -> key * 'a
          val max_binding : 'a t -> key * 'a
          val choose : 'a t -> key * 'a
          val split : key -> 'a t -> 'a t * 'a option * 'a t
          val find : key -> 'a t -> 'a
          val map : ('-> 'b) -> 'a t -> 'b t
          val mapi : (key -> '-> 'b) -> 'a t -> 'b t
          val dom : 'As_path.Rel.t -> As_path.Rel.Set.t
        end
    end
  module Abs :
    sig
      type path = As_path.t
      type t = As_path.abs
      val root : As_path.abs
      val add : As_path.abs -> string -> As_path.abs
      val concat : As_path.abs -> As_path.rel -> As_path.abs
      val ( / ) : As_path.abs -> string -> As_path.abs
      val ( // ) : As_path.abs -> As_path.rel -> As_path.abs
      val basename : As_path.abs -> string
      val dirname : As_path.abs -> As_path.abs
      val rem_prefix : As_path.abs -> As_path.abs -> As_path.rel option
      val find_prefix : As_path.abs -> As_path.abs -> As_path.abs
      val is_root : As_path.abs -> bool
      val is_prefix : As_path.abs -> As_path.abs -> bool
      val equal : As_path.abs -> As_path.abs -> bool
      val compare : As_path.abs -> As_path.abs -> int
      val to_segs : As_path.abs -> string list
      val of_segs : string list -> As_path.abs
      val to_string : As_path.abs -> string
      val quote : As_path.abs -> string
      val pp : Format.formatter -> As_path.abs -> unit
      val ext : As_path.abs -> As_path.ext option
      val get_ext : As_path.abs -> As_path.ext
      val add_ext : As_path.abs -> As_path.ext -> As_path.abs
      val rem_ext : As_path.abs -> As_path.abs
      val change_ext : As_path.abs -> As_path.ext -> As_path.abs
      val ( + ) : As_path.abs -> As_path.ext -> As_path.abs
      val has_ext : As_path.ext -> As_path.abs -> bool
      val ext_matches : As_path.ext list -> As_path.abs -> bool
      module Set :
        sig
          type elt = abs
          type t
          val empty : t
          val is_empty : t -> bool
          val mem : elt -> t -> bool
          val add : elt -> t -> t
          val singleton : elt -> t
          val remove : elt -> t -> t
          val union : t -> t -> t
          val inter : t -> t -> t
          val diff : t -> t -> t
          val compare : t -> t -> int
          val equal : t -> t -> bool
          val subset : t -> t -> bool
          val iter : (elt -> unit) -> t -> unit
          val fold : (elt -> '-> 'a) -> t -> '-> 'a
          val for_all : (elt -> bool) -> t -> bool
          val exists : (elt -> bool) -> t -> bool
          val filter : (elt -> bool) -> t -> t
          val partition : (elt -> bool) -> t -> t * t
          val cardinal : t -> int
          val elements : t -> elt list
          val min_elt : t -> elt
          val max_elt : t -> elt
          val choose : t -> elt
          val split : elt -> t -> t * bool * t
          val find : elt -> t -> elt
          val of_list : elt list -> As_path.Abs.t
        end
      module Map :
        sig
          type key = abs
          type +'a t
          val empty : 'a t
          val is_empty : 'a t -> bool
          val mem : key -> 'a t -> bool
          val add : key -> '-> 'a t -> 'a t
          val singleton : key -> '-> 'a t
          val remove : key -> 'a t -> 'a t
          val merge :
            (key -> 'a option -> 'b option -> 'c option) ->
            'a t -> 'b t -> 'c t
          val compare : ('-> '-> int) -> 'a t -> 'a t -> int
          val equal : ('-> '-> bool) -> 'a t -> 'a t -> bool
          val iter : (key -> '-> unit) -> 'a t -> unit
          val fold : (key -> '-> '-> 'b) -> 'a t -> '-> 'b
          val for_all : (key -> '-> bool) -> 'a t -> bool
          val exists : (key -> '-> bool) -> 'a t -> bool
          val filter : (key -> '-> bool) -> 'a t -> 'a t
          val partition : (key -> '-> bool) -> 'a t -> 'a t * 'a t
          val cardinal : 'a t -> int
          val bindings : 'a t -> (key * 'a) list
          val min_binding : 'a t -> key * 'a
          val max_binding : 'a t -> key * 'a
          val choose : 'a t -> key * 'a
          val split : key -> 'a t -> 'a t * 'a option * 'a t
          val find : key -> 'a t -> 'a
          val map : ('-> 'b) -> 'a t -> 'b t
          val mapi : (key -> '-> 'b) -> 'a t -> 'b t
          val dom : 'As_path.Abs.t -> As_path.Abs.Set.t
        end
    end
  module Set :
    sig
      type elt = t
      type t
      val empty : t
      val is_empty : t -> bool
      val mem : elt -> t -> bool
      val add : elt -> t -> t
      val singleton : elt -> t
      val remove : elt -> t -> t
      val union : t -> t -> t
      val inter : t -> t -> t
      val diff : t -> t -> t
      val compare : t -> t -> int
      val equal : t -> t -> bool
      val subset : t -> t -> bool
      val iter : (elt -> unit) -> t -> unit
      val fold : (elt -> '-> 'a) -> t -> '-> 'a
      val for_all : (elt -> bool) -> t -> bool
      val exists : (elt -> bool) -> t -> bool
      val filter : (elt -> bool) -> t -> t
      val partition : (elt -> bool) -> t -> t * t
      val cardinal : t -> int
      val elements : t -> elt list
      val min_elt : t -> elt
      val max_elt : t -> elt
      val choose : t -> elt
      val split : elt -> t -> t * bool * t
      val find : elt -> t -> elt
      val of_list : elt list -> As_path.t
    end
  module Map :
    sig
      type key = t
      type +'a t
      val empty : 'a t
      val is_empty : 'a t -> bool
      val mem : key -> 'a t -> bool
      val add : key -> '-> 'a t -> 'a t
      val singleton : key -> '-> 'a t
      val remove : key -> 'a t -> 'a t
      val merge :
        (key -> 'a option -> 'b option -> 'c option) -> 'a t -> 'b t -> 'c t
      val compare : ('-> '-> int) -> 'a t -> 'a t -> int
      val equal : ('-> '-> bool) -> 'a t -> 'a t -> bool
      val iter : (key -> '-> unit) -> 'a t -> unit
      val fold : (key -> '-> '-> 'b) -> 'a t -> '-> 'b
      val for_all : (key -> '-> bool) -> 'a t -> bool
      val exists : (key -> '-> bool) -> 'a t -> bool
      val filter : (key -> '-> bool) -> 'a t -> 'a t
      val partition : (key -> '-> bool) -> 'a t -> 'a t * 'a t
      val cardinal : 'a t -> int
      val bindings : 'a t -> (key * 'a) list
      val min_binding : 'a t -> key * 'a
      val max_binding : 'a t -> key * 'a
      val choose : 'a t -> key * 'a
      val split : key -> 'a t -> 'a t * 'a option * 'a t
      val find : key -> 'a t -> 'a
      val map : ('-> 'b) -> 'a t -> 'b t
      val mapi : (key -> '-> 'b) -> 'a t -> 'b t
      val dom : 'As_path.t -> As_path.Set.t
    end
end