4.2.10. GNATCOLL.File_Paths

package GNATCOLL.File_Paths is

   Path_Separator : constant Character;
   --  Default path separator on the current platform

   type Any_Path is private;
   --  Path where to look for files, i.e. sequence of directories

   type CWD_Mode is (If_Empty, CWD_First, CWD_Last);
   --  Control how to include the current working directory (CWD) to a path.
   --
   --  ``If_Empty``: automatically append it if the path would otherwise be
   --  empty.
   --
   --  ``CWD_First``: automatically append it first in the path (i.e. files are
   --  searched in priority in the CWD).
   --
   --  ``CWD_Last``: automatically append it last in the path (i.e. files are
   --  searched in the CWD as a last tentative).

   function Create_Path
     (Directories : XString_Array;
      CWD         : CWD_Mode := CWD_First) return Any_Path;
   --  Create a path for the given ``Directories`` (first directories are
   --  looked up before the next ones). ``CWD`` controls how to include the
   --  current working directory.

   function Create_Path_From_Environ
     (Var_Name  : String;
      Separator : Character := Path_Separator;
      CWD       : CWD_Mode := CWD_First) return Any_Path;
   --  Create a path for the directories listed in the ``Var_Name`` environment
   --  variable. Each path component is separated by ``Separator``. ``CWD``
   --  controls how to include the current working directory.

   function Parse_Path
     (Path      : String;
      Separator : Character := Path_Separator;
      CWD       : CWD_Mode := CWD_First) return Any_Path;
   --  Parse a path from the ``Path`` string. Each path component is separated
   --  by ``Separator``. ``CWD`` controls how to include the current working
   --  directory.

   procedure Add_Directory (Path : in out Any_Path; Directory : String);
   --  Add ``Directory`` to the given ``Path``. This new directory takes
   --  precedence over the existing ones for file lookups.

   function Lookup (Path : Any_Path; Filename : String) return String;
   --  Look for a filed called ``Filename`` in directories referenced by
   --  ``Path`` and return its absolute file name. If the file is not found,
   --  return an empty string.

   Empty_Path : constant Any_Path;
   --  Path for which only lookups on existing absolute file names will succeed

end GNATCOLL.File_Paths;