aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.7/gcc/ada/prj-tree.ads
diff options
context:
space:
mode:
Diffstat (limited to 'gcc-4.7/gcc/ada/prj-tree.ads')
-rw-r--r--gcc-4.7/gcc/ada/prj-tree.ads1530
1 files changed, 0 insertions, 1530 deletions
diff --git a/gcc-4.7/gcc/ada/prj-tree.ads b/gcc-4.7/gcc/ada/prj-tree.ads
deleted file mode 100644
index a16409965..000000000
--- a/gcc-4.7/gcc/ada/prj-tree.ads
+++ /dev/null
@@ -1,1530 +0,0 @@
-------------------------------------------------------------------------------
--- --
--- GNAT COMPILER COMPONENTS --
--- --
--- P R J . T R E E --
--- --
--- S p e c --
--- --
--- Copyright (C) 2001-2011, Free Software Foundation, Inc. --
--- --
--- GNAT is free software; you can redistribute it and/or modify it under --
--- terms of the GNU General Public License as published by the Free Soft- --
--- ware Foundation; either version 3, or (at your option) any later ver- --
--- sion. GNAT is distributed in the hope that it will be useful, but WITH- --
--- OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY --
--- or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License --
--- for more details. You should have received a copy of the GNU General --
--- Public License distributed with GNAT; see file COPYING3. If not, go to --
--- http://www.gnu.org/licenses for a complete copy of the license. --
--- --
--- GNAT was originally developed by the GNAT team at New York University. --
--- Extensive contributions were provided by Ada Core Technologies Inc. --
--- --
-------------------------------------------------------------------------------
-
--- This package defines the structure of the Project File tree
-
-with GNAT.Dynamic_HTables;
-with GNAT.Dynamic_Tables;
-
-with Table;
-
-with Prj.Attr; use Prj.Attr;
-with Prj.Env;
-with Prj.Ext;
-
-package Prj.Tree is
-
- -----------------
- -- Environment --
- -----------------
-
- -- The following record contains the context in which projects are parsed
- -- and processed (finding importing project, resolving external values,..).
-
- type Environment is record
- External : Prj.Ext.External_References;
- -- External references are stored in this hash table (and manipulated
- -- through subprograms in prj-ext.ads). External references are
- -- project-tree specific so that one can load the same tree twice but
- -- have two views of it, for instance.
-
- Project_Path : aliased Prj.Env.Project_Search_Path;
- -- The project path is tree specific, since we might want to load
- -- simultaneously multiple projects, each with its own search path, in
- -- particular when using different compilers with different default
- -- search directories.
-
- Flags : Prj.Processing_Flags;
- -- Configure errors and warnings
- end record;
-
- procedure Initialize
- (Self : out Environment;
- Flags : Processing_Flags);
- -- Initialize a new environment
-
- procedure Initialize_And_Copy
- (Self : out Environment;
- Copy_From : Environment);
- -- Initialize a new environment, copying its values from Copy_From
-
- procedure Free (Self : in out Environment);
- -- Free the memory used by Self
-
- procedure Override_Flags
- (Self : in out Environment; Flags : Prj.Processing_Flags);
- -- Override the subprogram called in case there are parsing errors. This
- -- is needed in applications that do their own error handling, since the
- -- error handler is likely to be a local subprogram in this case (which
- -- can't be stored when the flags are created).
-
- -------------------
- -- Project nodes --
- -------------------
-
- type Project_Node_Tree_Data;
- type Project_Node_Tree_Ref is access all Project_Node_Tree_Data;
- -- Type to designate a project node tree, so that several project node
- -- trees can coexist in memory.
-
- Project_Nodes_Initial : constant := 1_000;
- Project_Nodes_Increment : constant := 100;
- -- Allocation parameters for initializing and extending number
- -- of nodes in table Tree_Private_Part.Project_Nodes
-
- Project_Node_Low_Bound : constant := 0;
- Project_Node_High_Bound : constant := 099_999_999;
- -- Range of values for project node id's (in practice infinite)
-
- type Project_Node_Id is range
- Project_Node_Low_Bound .. Project_Node_High_Bound;
- -- The index of table Tree_Private_Part.Project_Nodes
-
- Empty_Node : constant Project_Node_Id := Project_Node_Low_Bound;
- -- Designates no node in table Project_Nodes
-
- First_Node_Id : constant Project_Node_Id := Project_Node_Low_Bound + 1;
-
- subtype Variable_Node_Id is Project_Node_Id;
- -- Used to designate a node whose expected kind is one of
- -- N_Typed_Variable_Declaration, N_Variable_Declaration or
- -- N_Variable_Reference.
-
- subtype Package_Declaration_Id is Project_Node_Id;
- -- Used to designate a node whose expected kind is N_Project_Declaration
-
- type Project_Node_Kind is
- (N_Project,
- N_With_Clause,
- N_Project_Declaration,
- N_Declarative_Item,
- N_Package_Declaration,
- N_String_Type_Declaration,
- N_Literal_String,
- N_Attribute_Declaration,
- N_Typed_Variable_Declaration,
- N_Variable_Declaration,
- N_Expression,
- N_Term,
- N_Literal_String_List,
- N_Variable_Reference,
- N_External_Value,
- N_Attribute_Reference,
- N_Case_Construction,
- N_Case_Item,
- N_Comment_Zones,
- N_Comment);
- -- Each node in the tree is of a Project_Node_Kind. For the signification
- -- of the fields in each node of Project_Node_Kind, look at package
- -- Tree_Private_Part.
-
- function Present (Node : Project_Node_Id) return Boolean;
- pragma Inline (Present);
- -- Return True if Node /= Empty_Node
-
- function No (Node : Project_Node_Id) return Boolean;
- pragma Inline (No);
- -- Return True if Node = Empty_Node
-
- procedure Initialize (Tree : Project_Node_Tree_Ref);
- -- Initialize the Project File tree: empty the Project_Nodes table
- -- and reset the Projects_Htable.
-
- function Default_Project_Node
- (In_Tree : Project_Node_Tree_Ref;
- Of_Kind : Project_Node_Kind;
- And_Expr_Kind : Variable_Kind := Undefined) return Project_Node_Id;
- -- Returns a Project_Node_Record with the specified Kind and Expr_Kind. All
- -- the other components have default nil values.
- -- To create a node for a project itself, see Create_Project below instead
-
- function Hash (N : Project_Node_Id) return Header_Num;
- -- Used for hash tables where the key is a Project_Node_Id
-
- function Imported_Or_Extended_Project_Of
- (Project : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- With_Name : Name_Id) return Project_Node_Id;
- -- Return the node of a project imported or extended by project Project and
- -- whose name is With_Name. Return Empty_Node if there is no such project.
-
- --------------
- -- Comments --
- --------------
-
- type Comment_State is private;
- -- A type to store the values of several global variables related to
- -- comments.
-
- procedure Save (S : out Comment_State);
- -- Save in variable S the comment state. Called before scanning a new
- -- project file.
-
- procedure Restore_And_Free (S : in out Comment_State);
- -- Restore the comment state to a previously saved value. Called after
- -- scanning a project file. Frees the memory occupied by S
-
- procedure Reset_State;
- -- Set the comment state to its initial value. Called before scanning a
- -- new project file.
-
- function There_Are_Unkept_Comments return Boolean;
- -- Indicates that some of the comments in a project file could not be
- -- stored in the parse tree.
-
- procedure Set_Previous_Line_Node (To : Project_Node_Id);
- -- Indicate the node on the previous line. If there are comments
- -- immediately following this line, then they should be associated with
- -- this node.
-
- procedure Set_Previous_End_Node (To : Project_Node_Id);
- -- Indicate that on the previous line the "end" belongs to node To.
- -- If there are comments immediately following this "end" line, they
- -- should be associated with this node.
-
- procedure Set_End_Of_Line (To : Project_Node_Id);
- -- Indicate the node on the current line. If there is an end of line
- -- comment, then it should be associated with this node.
-
- procedure Set_Next_End_Node (To : Project_Node_Id);
- -- Put node To on the top of the end node stack. When an END line is found
- -- with this node on the top of the end node stack, the comments, if any,
- -- immediately preceding this "end" line will be associated with this node.
-
- procedure Remove_Next_End_Node;
- -- Remove the top of the end node stack
-
- ------------------------
- -- Comment Processing --
- ------------------------
-
- type Comment_Data is record
- Value : Name_Id := No_Name;
- Follows_Empty_Line : Boolean := False;
- Is_Followed_By_Empty_Line : Boolean := False;
- end record;
- -- Component type for Comments Table below
-
- package Comments is new Table.Table
- (Table_Component_Type => Comment_Data,
- Table_Index_Type => Natural,
- Table_Low_Bound => 1,
- Table_Initial => 10,
- Table_Increment => 100,
- Table_Name => "Prj.Tree.Comments");
- -- A table to store the comments that may be stored is the tree
-
- procedure Scan (In_Tree : Project_Node_Tree_Ref);
- -- Scan the tokens and accumulate comments
-
- type Comment_Location is
- (Before, After, Before_End, After_End, End_Of_Line);
- -- Used in call to Add_Comments below
-
- procedure Add_Comments
- (To : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- Where : Comment_Location);
- -- Add comments to this node
-
- ----------------------
- -- Access Functions --
- ----------------------
-
- -- The following query functions are part of the abstract interface
- -- of the Project File tree. They provide access to fields of a project.
-
- -- The access functions should be called only with valid arguments.
- -- For each function the condition of validity is specified. If an access
- -- function is called with invalid arguments, then exception
- -- Assertion_Error is raised if assertions are enabled, otherwise the
- -- behaviour is not defined and may result in a crash.
-
- function Name_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Name_Id;
- pragma Inline (Name_Of);
- -- Valid for all non empty nodes. May return No_Name for nodes that have
- -- no names.
-
- function Kind_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Kind;
- pragma Inline (Kind_Of);
- -- Valid for all non empty nodes
-
- function Location_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Source_Ptr;
- pragma Inline (Location_Of);
- -- Valid for all non empty nodes
-
- function First_Comment_After
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- -- Valid only for N_Comment_Zones nodes
-
- function First_Comment_After_End
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- -- Valid only for N_Comment_Zones nodes
-
- function First_Comment_Before
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- -- Valid only for N_Comment_Zones nodes
-
- function First_Comment_Before_End
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- -- Valid only for N_Comment_Zones nodes
-
- function Next_Comment
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- -- Valid only for N_Comment nodes
-
- function End_Of_Line_Comment
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Name_Id;
- -- Valid only for non empty nodes
-
- function Follows_Empty_Line
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Boolean;
- -- Valid only for N_Comment nodes
-
- function Is_Followed_By_Empty_Line
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Boolean;
- -- Valid only for N_Comment nodes
-
- function Parent_Project_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Parent_Project_Of);
- -- Valid only for N_Project nodes
-
- function Project_File_Includes_Unkept_Comments
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Boolean;
- -- Valid only for N_Project nodes
-
- function Directory_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Path_Name_Type;
- pragma Inline (Directory_Of);
- -- Returns the directory that contains the project file. This always ends
- -- with a directory separator. Only valid for N_Project nodes.
-
- function Expression_Kind_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Variable_Kind;
- pragma Inline (Expression_Kind_Of);
- -- Only valid for N_Literal_String, N_Attribute_Declaration,
- -- N_Variable_Declaration, N_Typed_Variable_Declaration, N_Expression,
- -- N_Term, N_Variable_Reference, N_Attribute_Reference nodes or
- -- N_External_Value.
-
- function Is_Extending_All
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Boolean;
- pragma Inline (Is_Extending_All);
- -- Only valid for N_Project and N_With_Clause
-
- function Is_Not_Last_In_List
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Boolean;
- pragma Inline (Is_Not_Last_In_List);
- -- Only valid for N_With_Clause
-
- function First_Variable_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Variable_Node_Id;
- pragma Inline (First_Variable_Of);
- -- Only valid for N_Project or N_Package_Declaration nodes
-
- function First_Package_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Package_Declaration_Id;
- pragma Inline (First_Package_Of);
- -- Only valid for N_Project nodes
-
- function Package_Id_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Package_Node_Id;
- pragma Inline (Package_Id_Of);
- -- Only valid for N_Package_Declaration nodes
-
- function Path_Name_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Path_Name_Type;
- pragma Inline (Path_Name_Of);
- -- Only valid for N_Project and N_With_Clause nodes
-
- function String_Value_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Name_Id;
- pragma Inline (String_Value_Of);
- -- Only valid for N_With_Clause, N_Literal_String nodes or N_Comment.
- -- For a N_With_Clause created automatically for a virtual extending
- -- project, No_Name is returned.
-
- function Source_Index_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Int;
- pragma Inline (Source_Index_Of);
- -- Only valid for N_Literal_String and N_Attribute_Declaration nodes
-
- function First_With_Clause_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (First_With_Clause_Of);
- -- Only valid for N_Project nodes
-
- function Project_Declaration_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Project_Declaration_Of);
- -- Only valid for N_Project nodes
-
- function Project_Qualifier_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Qualifier;
- pragma Inline (Project_Qualifier_Of);
- -- Only valid for N_Project nodes
-
- function Extending_Project_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Extending_Project_Of);
- -- Only valid for N_Project_Declaration nodes
-
- function First_String_Type_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (First_String_Type_Of);
- -- Only valid for N_Project nodes
-
- function Extended_Project_Path_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Path_Name_Type;
- pragma Inline (Extended_Project_Path_Of);
- -- Only valid for N_With_Clause nodes
-
- function Project_Node_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Project_Node_Of);
- -- Only valid for N_With_Clause, N_Variable_Reference and
- -- N_Attribute_Reference nodes.
-
- function Non_Limited_Project_Node_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Non_Limited_Project_Node_Of);
- -- Only valid for N_With_Clause nodes. Returns Empty_Node for limited
- -- imported project files, otherwise returns the same result as
- -- Project_Node_Of.
-
- function Next_With_Clause_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Next_With_Clause_Of);
- -- Only valid for N_With_Clause nodes
-
- function First_Declarative_Item_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (First_Declarative_Item_Of);
- -- Only valid for N_Project_Declaration, N_Case_Item and
- -- N_Package_Declaration.
-
- function Extended_Project_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Extended_Project_Of);
- -- Only valid for N_Project_Declaration nodes
-
- function Current_Item_Node
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Current_Item_Node);
- -- Only valid for N_Declarative_Item nodes
-
- function Next_Declarative_Item
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Next_Declarative_Item);
- -- Only valid for N_Declarative_Item node
-
- function Project_Of_Renamed_Package_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Project_Of_Renamed_Package_Of);
- -- Only valid for N_Package_Declaration nodes. May return Empty_Node.
-
- function Next_Package_In_Project
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Next_Package_In_Project);
- -- Only valid for N_Package_Declaration nodes
-
- function First_Literal_String
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (First_Literal_String);
- -- Only valid for N_String_Type_Declaration nodes
-
- function Next_String_Type
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Next_String_Type);
- -- Only valid for N_String_Type_Declaration nodes
-
- function Next_Literal_String
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Next_Literal_String);
- -- Only valid for N_Literal_String nodes
-
- function Expression_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Expression_Of);
- -- Only valid for N_Attribute_Declaration, N_Typed_Variable_Declaration
- -- or N_Variable_Declaration nodes
-
- function Associative_Project_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref)
- return Project_Node_Id;
- pragma Inline (Associative_Project_Of);
- -- Only valid for N_Attribute_Declaration nodes
-
- function Associative_Package_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref)
- return Project_Node_Id;
- pragma Inline (Associative_Package_Of);
- -- Only valid for N_Attribute_Declaration nodes
-
- function Value_Is_Valid
- (For_Typed_Variable : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- Value : Name_Id) return Boolean;
- pragma Inline (Value_Is_Valid);
- -- Only valid for N_Typed_Variable_Declaration. Returns True if Value is
- -- in the list of allowed strings for For_Typed_Variable. False otherwise.
-
- function Associative_Array_Index_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Name_Id;
- pragma Inline (Associative_Array_Index_Of);
- -- Only valid for N_Attribute_Declaration and N_Attribute_Reference.
- -- Returns No_Name for non associative array attributes.
-
- function Next_Variable
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Next_Variable);
- -- Only valid for N_Typed_Variable_Declaration or N_Variable_Declaration
- -- nodes.
-
- function First_Term
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (First_Term);
- -- Only valid for N_Expression nodes
-
- function Next_Expression_In_List
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Next_Expression_In_List);
- -- Only valid for N_Expression nodes
-
- function Current_Term
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Current_Term);
- -- Only valid for N_Term nodes
-
- function Next_Term
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Next_Term);
- -- Only valid for N_Term nodes
-
- function First_Expression_In_List
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (First_Expression_In_List);
- -- Only valid for N_Literal_String_List nodes
-
- function Package_Node_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Package_Node_Of);
- -- Only valid for N_Variable_Reference or N_Attribute_Reference nodes.
- -- May return Empty_Node.
-
- function String_Type_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (String_Type_Of);
- -- Only valid for N_Variable_Reference or N_Typed_Variable_Declaration
- -- nodes.
-
- function External_Reference_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (External_Reference_Of);
- -- Only valid for N_External_Value nodes
-
- function External_Default_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (External_Default_Of);
- -- Only valid for N_External_Value nodes
-
- function Case_Variable_Reference_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Case_Variable_Reference_Of);
- -- Only valid for N_Case_Construction nodes
-
- function First_Case_Item_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (First_Case_Item_Of);
- -- Only valid for N_Case_Construction nodes
-
- function First_Choice_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (First_Choice_Of);
- -- Only valid for N_Case_Item nodes. Return the first choice in a
- -- N_Case_Item, or Empty_Node if this is when others.
-
- function Next_Case_Item
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- pragma Inline (Next_Case_Item);
- -- Only valid for N_Case_Item nodes
-
- function Case_Insensitive
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref) return Boolean;
- -- Only valid for N_Attribute_Declaration and N_Attribute_Reference nodes
-
- -----------------------
- -- Create procedures --
- -----------------------
- -- The following procedures are used to edit a project file tree. They are
- -- slightly higher-level than the Set_* procedures below
-
- function Create_Project
- (In_Tree : Project_Node_Tree_Ref;
- Name : Name_Id;
- Full_Path : Path_Name_Type;
- Is_Config_File : Boolean := False) return Project_Node_Id;
- -- Create a new node for a project and register it in the tree so that it
- -- can be retrieved later on.
-
- function Create_Package
- (Tree : Project_Node_Tree_Ref;
- Project : Project_Node_Id;
- Pkg : String) return Project_Node_Id;
- -- Create a new package in Project. If the package already exists, it is
- -- returned. The name of the package *must* be lower-cases, or none of its
- -- attributes will be recognized.
-
- function Create_Attribute
- (Tree : Project_Node_Tree_Ref;
- Prj_Or_Pkg : Project_Node_Id;
- Name : Name_Id;
- Index_Name : Name_Id := No_Name;
- Kind : Variable_Kind := List;
- At_Index : Integer := 0;
- Value : Project_Node_Id := Empty_Node) return Project_Node_Id;
- -- Create a new attribute. The new declaration is added at the end of the
- -- declarative item list for Prj_Or_Pkg (a project or a package), but
- -- before any package declaration). No addition is done if Prj_Or_Pkg is
- -- Empty_Node. If Index_Name is not "", then if creates an attribute value
- -- for a specific index. At_Index is used for the " at <idx>" in the naming
- -- exceptions.
- --
- -- To set the value of the attribute, either provide a value for Value, or
- -- use Set_Expression_Of to set the value of the attribute (in which case
- -- Enclose_In_Expression might be useful). The former is recommended since
- -- it will more correctly handle cases where the index needs to be set on
- -- the expression rather than on the index of the attribute (i.e. 'for
- -- Specification ("unit") use "file" at 3', versus 'for Executable ("file"
- -- at 3) use "name"'). Value must be a N_String_Literal if an index will be
- -- added to it.
-
- function Create_Literal_String
- (Str : Namet.Name_Id;
- Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- -- Create a literal string whose value is Str
-
- procedure Add_At_End
- (Tree : Project_Node_Tree_Ref;
- Parent : Project_Node_Id;
- Expr : Project_Node_Id;
- Add_Before_First_Pkg : Boolean := False;
- Add_Before_First_Case : Boolean := False);
- -- Add a new declarative item in the list in Parent. This new declarative
- -- item will contain Expr (unless Expr is already a declarative item, in
- -- which case it is added directly to the list). The new item is inserted
- -- at the end of the list, unless Add_Before_First_Pkg is True. In the
- -- latter case, it is added just before the first case construction is
- -- seen, or before the first package (this assumes that all packages are
- -- found at the end of the project, which isn't true in the general case
- -- unless you have normalized the project to match this description).
-
- function Enclose_In_Expression
- (Node : Project_Node_Id;
- Tree : Project_Node_Tree_Ref) return Project_Node_Id;
- -- Enclose the Node inside a N_Expression node, and return this expression.
- -- This does nothing if Node is already a N_Expression.
-
- --------------------
- -- Set Procedures --
- --------------------
-
- -- The following procedures are part of the abstract interface of the
- -- Project File tree.
-
- -- Foe each Set_* procedure the condition of validity is specified. If an
- -- access function is called with invalid arguments, then exception
- -- Assertion_Error is raised if assertions are enabled, otherwise the
- -- behaviour is not defined and may result in a crash.
-
- -- These are very low-level, and manipulate the tree itself directly. You
- -- should look at the Create_* procedure instead if you want to use higher
- -- level constructs
-
- procedure Set_Name_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Name_Id);
- pragma Inline (Set_Name_Of);
- -- Valid for all non empty nodes.
-
- procedure Set_Kind_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Kind);
- pragma Inline (Set_Kind_Of);
- -- Valid for all non empty nodes
-
- procedure Set_Location_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Source_Ptr);
- pragma Inline (Set_Location_Of);
- -- Valid for all non empty nodes
-
- procedure Set_First_Comment_After
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_First_Comment_After);
- -- Valid only for N_Comment_Zones nodes
-
- procedure Set_First_Comment_After_End
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_First_Comment_After_End);
- -- Valid only for N_Comment_Zones nodes
-
- procedure Set_First_Comment_Before
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_First_Comment_Before);
- -- Valid only for N_Comment_Zones nodes
-
- procedure Set_First_Comment_Before_End
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_First_Comment_Before_End);
- -- Valid only for N_Comment_Zones nodes
-
- procedure Set_Next_Comment
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Next_Comment);
- -- Valid only for N_Comment nodes
-
- procedure Set_Parent_Project_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- -- Valid only for N_Project nodes
-
- procedure Set_Project_File_Includes_Unkept_Comments
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Boolean);
- -- Valid only for N_Project nodes
-
- procedure Set_Directory_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Path_Name_Type);
- pragma Inline (Set_Directory_Of);
- -- Valid only for N_Project nodes
-
- procedure Set_Expression_Kind_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Variable_Kind);
- pragma Inline (Set_Expression_Kind_Of);
- -- Only valid for N_Literal_String, N_Attribute_Declaration,
- -- N_Variable_Declaration, N_Typed_Variable_Declaration, N_Expression,
- -- N_Term, N_Variable_Reference, N_Attribute_Reference or N_External_Value
- -- nodes.
-
- procedure Set_Is_Extending_All
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref);
- pragma Inline (Set_Is_Extending_All);
- -- Only valid for N_Project and N_With_Clause
-
- procedure Set_Is_Not_Last_In_List
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref);
- pragma Inline (Set_Is_Not_Last_In_List);
- -- Only valid for N_With_Clause
-
- procedure Set_First_Variable_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Variable_Node_Id);
- pragma Inline (Set_First_Variable_Of);
- -- Only valid for N_Project or N_Package_Declaration nodes
-
- procedure Set_First_Package_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Package_Declaration_Id);
- pragma Inline (Set_First_Package_Of);
- -- Only valid for N_Project nodes
-
- procedure Set_Package_Id_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Package_Node_Id);
- pragma Inline (Set_Package_Id_Of);
- -- Only valid for N_Package_Declaration nodes
-
- procedure Set_Path_Name_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Path_Name_Type);
- pragma Inline (Set_Path_Name_Of);
- -- Only valid for N_Project and N_With_Clause nodes
-
- procedure Set_String_Value_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Name_Id);
- pragma Inline (Set_String_Value_Of);
- -- Only valid for N_With_Clause, N_Literal_String nodes or N_Comment.
-
- procedure Set_Source_Index_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Int);
- pragma Inline (Set_Source_Index_Of);
- -- Only valid for N_Literal_String and N_Attribute_Declaration nodes. For
- -- N_Literal_String, set the source index of the literal string. For
- -- N_Attribute_Declaration, set the source index of the index of the
- -- associative array element.
-
- procedure Set_First_With_Clause_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_First_With_Clause_Of);
- -- Only valid for N_Project nodes
-
- procedure Set_Project_Declaration_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Project_Declaration_Of);
- -- Only valid for N_Project nodes
-
- procedure Set_Project_Qualifier_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Qualifier);
- pragma Inline (Set_Project_Qualifier_Of);
- -- Only valid for N_Project nodes
-
- procedure Set_Extending_Project_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Extending_Project_Of);
- -- Only valid for N_Project_Declaration nodes
-
- procedure Set_First_String_Type_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_First_String_Type_Of);
- -- Only valid for N_Project nodes
-
- procedure Set_Extended_Project_Path_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Path_Name_Type);
- pragma Inline (Set_Extended_Project_Path_Of);
- -- Only valid for N_With_Clause nodes
-
- procedure Set_Project_Node_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id;
- Limited_With : Boolean := False);
- pragma Inline (Set_Project_Node_Of);
- -- Only valid for N_With_Clause, N_Variable_Reference and
- -- N_Attribute_Reference nodes.
-
- procedure Set_Next_With_Clause_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Next_With_Clause_Of);
- -- Only valid for N_With_Clause nodes
-
- procedure Set_First_Declarative_Item_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_First_Declarative_Item_Of);
- -- Only valid for N_Project_Declaration, N_Case_Item and
- -- N_Package_Declaration.
-
- procedure Set_Extended_Project_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Extended_Project_Of);
- -- Only valid for N_Project_Declaration nodes
-
- procedure Set_Current_Item_Node
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Current_Item_Node);
- -- Only valid for N_Declarative_Item nodes
-
- procedure Set_Next_Declarative_Item
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Next_Declarative_Item);
- -- Only valid for N_Declarative_Item node
-
- procedure Set_Project_Of_Renamed_Package_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Project_Of_Renamed_Package_Of);
- -- Only valid for N_Package_Declaration nodes.
-
- procedure Set_Next_Package_In_Project
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Next_Package_In_Project);
- -- Only valid for N_Package_Declaration nodes
-
- procedure Set_First_Literal_String
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_First_Literal_String);
- -- Only valid for N_String_Type_Declaration nodes
-
- procedure Set_Next_String_Type
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Next_String_Type);
- -- Only valid for N_String_Type_Declaration nodes
-
- procedure Set_Next_Literal_String
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Next_Literal_String);
- -- Only valid for N_Literal_String nodes
-
- procedure Set_Expression_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Expression_Of);
- -- Only valid for N_Attribute_Declaration, N_Typed_Variable_Declaration
- -- or N_Variable_Declaration nodes
-
- procedure Set_Associative_Project_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Associative_Project_Of);
- -- Only valid for N_Attribute_Declaration nodes
-
- procedure Set_Associative_Package_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Associative_Package_Of);
- -- Only valid for N_Attribute_Declaration nodes
-
- procedure Set_Associative_Array_Index_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Name_Id);
- pragma Inline (Set_Associative_Array_Index_Of);
- -- Only valid for N_Attribute_Declaration and N_Attribute_Reference.
-
- procedure Set_Next_Variable
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Next_Variable);
- -- Only valid for N_Typed_Variable_Declaration or N_Variable_Declaration
- -- nodes.
-
- procedure Set_First_Term
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_First_Term);
- -- Only valid for N_Expression nodes
-
- procedure Set_Next_Expression_In_List
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Next_Expression_In_List);
- -- Only valid for N_Expression nodes
-
- procedure Set_Current_Term
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Current_Term);
- -- Only valid for N_Term nodes
-
- procedure Set_Next_Term
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Next_Term);
- -- Only valid for N_Term nodes
-
- procedure Set_First_Expression_In_List
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_First_Expression_In_List);
- -- Only valid for N_Literal_String_List nodes
-
- procedure Set_Package_Node_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Package_Node_Of);
- -- Only valid for N_Variable_Reference or N_Attribute_Reference nodes.
-
- procedure Set_String_Type_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_String_Type_Of);
- -- Only valid for N_Variable_Reference or N_Typed_Variable_Declaration
- -- nodes.
-
- procedure Set_External_Reference_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_External_Reference_Of);
- -- Only valid for N_External_Value nodes
-
- procedure Set_External_Default_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_External_Default_Of);
- -- Only valid for N_External_Value nodes
-
- procedure Set_Case_Variable_Reference_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Case_Variable_Reference_Of);
- -- Only valid for N_Case_Construction nodes
-
- procedure Set_First_Case_Item_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_First_Case_Item_Of);
- -- Only valid for N_Case_Construction nodes
-
- procedure Set_First_Choice_Of
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_First_Choice_Of);
- -- Only valid for N_Case_Item nodes.
-
- procedure Set_Next_Case_Item
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Project_Node_Id);
- pragma Inline (Set_Next_Case_Item);
- -- Only valid for N_Case_Item nodes.
-
- procedure Set_Case_Insensitive
- (Node : Project_Node_Id;
- In_Tree : Project_Node_Tree_Ref;
- To : Boolean);
- -- Only valid for N_Attribute_Declaration and N_Attribute_Reference nodes
-
- -------------------------------
- -- Restricted Access Section --
- -------------------------------
-
- package Tree_Private_Part is
-
- -- This is conceptually in the private part. However, for efficiency,
- -- some packages are accessing it directly.
-
- type Project_Node_Record is record
-
- Kind : Project_Node_Kind;
-
- Qualifier : Project_Qualifier := Unspecified;
-
- Location : Source_Ptr := No_Location;
-
- Directory : Path_Name_Type := No_Path;
- -- Only for N_Project
-
- Expr_Kind : Variable_Kind := Undefined;
- -- See below for what Project_Node_Kind it is used
-
- Variables : Variable_Node_Id := Empty_Node;
- -- First variable in a project or a package
-
- Packages : Package_Declaration_Id := Empty_Node;
- -- First package declaration in a project
-
- Pkg_Id : Package_Node_Id := Empty_Package;
- -- Only used for N_Package_Declaration
- --
- -- The component Pkg_Id is an entry into the table Package_Attributes
- -- (in Prj.Attr). It is used to indicate all the attributes of the
- -- package with their characteristics.
- --
- -- The tables Prj.Attr.Attributes and Prj.Attr.Package_Attributes
- -- are built once and for all through a call (from Prj.Initialize)
- -- to procedure Prj.Attr.Initialize. It is never modified after that.
-
- Name : Name_Id := No_Name;
- -- See below for what Project_Node_Kind it is used
-
- Src_Index : Int := 0;
- -- Index of a unit in a multi-unit source.
- -- Only for some N_Attribute_Declaration and N_Literal_String.
-
- Path_Name : Path_Name_Type := No_Path;
- -- See below for what Project_Node_Kind it is used
-
- Value : Name_Id := No_Name;
- -- See below for what Project_Node_Kind it is used
-
- Field1 : Project_Node_Id := Empty_Node;
- -- See below the meaning for each Project_Node_Kind
-
- Field2 : Project_Node_Id := Empty_Node;
- -- See below the meaning for each Project_Node_Kind
-
- Field3 : Project_Node_Id := Empty_Node;
- -- See below the meaning for each Project_Node_Kind
-
- Field4 : Project_Node_Id := Empty_Node;
- -- See below the meaning for each Project_Node_Kind
-
- Flag1 : Boolean := False;
- -- This flag is significant only for:
- --
- -- N_Attribute_Declaration and N_Attribute_Reference
- -- Indicates for an associative array attribute, that the
- -- index is case insensitive.
- --
- -- N_Comment
- -- Indicates that the comment is preceded by an empty line.
- --
- -- N_Project
- -- Indicates that there are comments in the project source that
- -- cannot be kept in the tree.
- --
- -- N_Project_Declaration
- -- Indicates that there are unkept comments in the project.
- --
- -- N_With_Clause
- -- Indicates that this is not the last with in a with clause.
- -- Set for "A", but not for "B" in with "B"; and with "A", "B";
-
- Flag2 : Boolean := False;
- -- This flag is significant only for:
- --
- -- N_Project
- -- Indicates that the project "extends all" another project.
- --
- -- N_Comment
- -- Indicates that the comment is followed by an empty line.
- --
- -- N_With_Clause
- -- Indicates that the originally imported project is an extending
- -- all project.
-
- Comments : Project_Node_Id := Empty_Node;
- -- For nodes other that N_Comment_Zones or N_Comment, designates the
- -- comment zones associated with the node.
- --
- -- For N_Comment_Zones, designates the comment after the "end" of
- -- the construct.
- --
- -- For N_Comment, designates the next comment, if any.
-
- end record;
-
- -- type Project_Node_Kind is
-
- -- (N_Project,
- -- -- Name: project name
- -- -- Path_Name: project path name
- -- -- Expr_Kind: Undefined
- -- -- Field1: first with clause
- -- -- Field2: project declaration
- -- -- Field3: first string type
- -- -- Field4: parent project, if any
- -- -- Value: extended project path name (if any)
-
- -- N_With_Clause,
- -- -- Name: imported project name
- -- -- Path_Name: imported project path name
- -- -- Expr_Kind: Undefined
- -- -- Field1: project node
- -- -- Field2: next with clause
- -- -- Field3: project node or empty if "limited with"
- -- -- Field4: not used
- -- -- Value: literal string withed
-
- -- N_Project_Declaration,
- -- -- Name: not used
- -- -- Path_Name: not used
- -- -- Expr_Kind: Undefined
- -- -- Field1: first declarative item
- -- -- Field2: extended project
- -- -- Field3: extending project
- -- -- Field4: not used
- -- -- Value: not used
-
- -- N_Declarative_Item,
- -- -- Name: not used
- -- -- Path_Name: not used
- -- -- Expr_Kind: Undefined
- -- -- Field1: current item node
- -- -- Field2: next declarative item
- -- -- Field3: not used
- -- -- Field4: not used
- -- -- Value: not used
-
- -- N_Package_Declaration,
- -- -- Name: package name
- -- -- Path_Name: not used
- -- -- Expr_Kind: Undefined
- -- -- Field1: project of renamed package (if any)
- -- -- Field2: first declarative item
- -- -- Field3: next package in project
- -- -- Field4: not used
- -- -- Value: not used
-
- -- N_String_Type_Declaration,
- -- -- Name: type name
- -- -- Path_Name: not used
- -- -- Expr_Kind: Undefined
- -- -- Field1: first literal string
- -- -- Field2: next string type
- -- -- Field3: not used
- -- -- Field4: not used
- -- -- Value: not used
-
- -- N_Literal_String,
- -- -- Name: not used
- -- -- Path_Name: not used
- -- -- Expr_Kind: Single
- -- -- Field1: next literal string
- -- -- Field2: not used
- -- -- Field3: not used
- -- -- Field4: not used
- -- -- Value: string value
-
- -- N_Attribute_Declaration,
- -- -- Name: attribute name
- -- -- Path_Name: not used
- -- -- Expr_Kind: attribute kind
- -- -- Field1: expression
- -- -- Field2: project of full associative array
- -- -- Field3: package of full associative array
- -- -- Field4: not used
- -- -- Value: associative array index
- -- -- (if an associative array element)
-
- -- N_Typed_Variable_Declaration,
- -- -- Name: variable name
- -- -- Path_Name: not used
- -- -- Expr_Kind: Single
- -- -- Field1: expression
- -- -- Field2: type of variable (N_String_Type_Declaration)
- -- -- Field3: next variable
- -- -- Field4: not used
- -- -- Value: not used
-
- -- N_Variable_Declaration,
- -- -- Name: variable name
- -- -- Path_Name: not used
- -- -- Expr_Kind: variable kind
- -- -- Field1: expression
- -- -- Field2: not used
- -- -- Field3 is used for next variable, instead of Field2,
- -- -- so that it is the same field for
- -- -- N_Variable_Declaration and
- -- -- N_Typed_Variable_Declaration
- -- -- Field3: next variable
- -- -- Field4: not used
- -- -- Value: not used
-
- -- N_Expression,
- -- -- Name: not used
- -- -- Path_Name: not used
- -- -- Expr_Kind: expression kind
- -- -- Field1: first term
- -- -- Field2: next expression in list
- -- -- Field3: not used
- -- -- Value: not used
-
- -- N_Term,
- -- -- Name: not used
- -- -- Path_Name: not used
- -- -- Expr_Kind: term kind
- -- -- Field1: current term
- -- -- Field2: next term in the expression
- -- -- Field3: not used
- -- -- Field4: not used
- -- -- Value: not used
-
- -- N_Literal_String_List,
- -- -- Designates a list of string expressions between brackets
- -- -- separated by commas. The string expressions are not necessarily
- -- -- literal strings.
- -- -- Name: not used
- -- -- Path_Name: not used
- -- -- Expr_Kind: List
- -- -- Field1: first expression
- -- -- Field2: not used
- -- -- Field3: not used
- -- -- Field4: not used
- -- -- Value: not used
-
- -- N_Variable_Reference,
- -- -- Name: variable name
- -- -- Path_Name: not used
- -- -- Expr_Kind: variable kind
- -- -- Field1: project (if specified)
- -- -- Field2: package (if specified)
- -- -- Field3: type of variable (N_String_Type_Declaration), if any
- -- -- Field4: not used
- -- -- Value: not used
-
- -- N_External_Value,
- -- -- Name: not used
- -- -- Path_Name: not used
- -- -- Expr_Kind: Single
- -- -- Field1: Name of the external reference (literal string)
- -- -- Field2: Default (literal string)
- -- -- Field3: not used
- -- -- Value: not used
-
- -- N_Attribute_Reference,
- -- -- Name: attribute name
- -- -- Path_Name: not used
- -- -- Expr_Kind: attribute kind
- -- -- Field1: project
- -- -- Field2: package (if attribute of a package)
- -- -- Field3: not used
- -- -- Field4: not used
- -- -- Value: associative array index
- -- -- (if an associative array element)
-
- -- N_Case_Construction,
- -- -- Name: not used
- -- -- Path_Name: not used
- -- -- Expr_Kind: Undefined
- -- -- Field1: case variable reference
- -- -- Field2: first case item
- -- -- Field3: not used
- -- -- Field4: not used
- -- -- Value: not used
-
- -- N_Case_Item
- -- -- Name: not used
- -- -- Path_Name: not used
- -- -- Expr_Kind: not used
- -- -- Field1: first choice (literal string), or Empty_Node
- -- -- for when others
- -- -- Field2: first declarative item
- -- -- Field3: next case item
- -- -- Field4: not used
- -- -- Value: not used
-
- -- N_Comment_zones
- -- -- Name: not used
- -- -- Path_Name: not used
- -- -- Expr_Kind: not used
- -- -- Field1: comment before the construct
- -- -- Field2: comment after the construct
- -- -- Field3: comment before the "end" of the construct
- -- -- Value: end of line comment
- -- -- Field4: not used
- -- -- Comments: comment after the "end" of the construct
-
- -- N_Comment
- -- -- Name: not used
- -- -- Path_Name: not used
- -- -- Expr_Kind: not used
- -- -- Field1: not used
- -- -- Field2: not used
- -- -- Field3: not used
- -- -- Field4: not used
- -- -- Value: comment
- -- -- Flag1: comment is preceded by an empty line
- -- -- Flag2: comment is followed by an empty line
- -- -- Comments: next comment
-
- package Project_Node_Table is new
- GNAT.Dynamic_Tables
- (Table_Component_Type => Project_Node_Record,
- Table_Index_Type => Project_Node_Id,
- Table_Low_Bound => First_Node_Id,
- Table_Initial => Project_Nodes_Initial,
- Table_Increment => Project_Nodes_Increment);
- -- Table contains the syntactic tree of project data from project files
-
- type Project_Name_And_Node is record
- Name : Name_Id;
- -- Name of the project
-
- Display_Name : Name_Id;
- -- The name of the project as it appears in the .gpr file
-
- Node : Project_Node_Id;
- -- Node of the project in table Project_Nodes
-
- Canonical_Path : Path_Name_Type;
- -- Resolved and canonical path of a real project file.
- -- No_Name in case of virtual projects.
-
- Extended : Boolean;
- -- True when the project is being extended by another project
-
- Proj_Qualifier : Project_Qualifier;
- -- The project qualifier of the project, if any
- end record;
-
- No_Project_Name_And_Node : constant Project_Name_And_Node :=
- (Name => No_Name,
- Display_Name => No_Name,
- Node => Empty_Node,
- Canonical_Path => No_Path,
- Extended => True,
- Proj_Qualifier => Unspecified);
-
- package Projects_Htable is new GNAT.Dynamic_HTables.Simple_HTable
- (Header_Num => Header_Num,
- Element => Project_Name_And_Node,
- No_Element => No_Project_Name_And_Node,
- Key => Name_Id,
- Hash => Hash,
- Equal => "=");
- -- This hash table contains a mapping of project names to project nodes.
- -- Note that this hash table contains only the nodes whose Kind is
- -- N_Project. It is used to find the node of a project from its name,
- -- and to verify if a project has already been parsed, knowing its name.
-
- end Tree_Private_Part;
-
- type Project_Node_Tree_Data is record
- Project_Nodes : Tree_Private_Part.Project_Node_Table.Instance;
- Projects_HT : Tree_Private_Part.Projects_Htable.Instance;
-
- Incomplete_With : Boolean := False;
- -- Set to True if the projects were loaded with the flag
- -- Ignore_Missing_With set to True, and there were indeed some with
- -- statements that could not be resolved
- end record;
-
- procedure Free (Proj : in out Project_Node_Tree_Ref);
- -- Free memory used by Prj
-
-private
- type Comment_Array is array (Positive range <>) of Comment_Data;
- type Comments_Ptr is access Comment_Array;
-
- type Comment_State is record
- End_Of_Line_Node : Project_Node_Id := Empty_Node;
- Previous_Line_Node : Project_Node_Id := Empty_Node;
- Previous_End_Node : Project_Node_Id := Empty_Node;
- Unkept_Comments : Boolean := False;
- Comments : Comments_Ptr := null;
- end record;
-
-end Prj.Tree;