summaryrefslogtreecommitdiff
path: root/gcc/ada
diff options
context:
space:
mode:
authorcharlet <charlet@138bc75d-0d04-0410-961f-82ee72b054a4>2005-12-09 17:19:49 +0000
committercharlet <charlet@138bc75d-0d04-0410-961f-82ee72b054a4>2005-12-09 17:19:49 +0000
commitd5bf49516dfde4e4708fc182e71564ea6875b18e (patch)
tree55fe007ea4d3250009db6cfbba847208f8c1e982 /gcc/ada
parent041a8137335bd09376b5cd405c99d1781b7884f1 (diff)
downloadgcc-d5bf49516dfde4e4708fc182e71564ea6875b18e.tar.gz
2005-12-05 Robert Dewar <dewar@adacore.com>
Ed Schonberg <schonberg@adacore.com> Gary Dismukes <dismukes@adacore.com> Javier Miranda <miranda@adacore.com> Hristian Kirtchev <kirtchev@adacore.com> * einfo.adb (Itype_Printed): New flag (Is_Limited_Type): Derived types do not inherit limitedness from interface progenitors. (Is_Return_By_Reference_Type): Predicate does not apply to limited interfaces. * einfo.ads (Itype_Printed): New flag Move Is_Wrapper_Package to proper section Add missing Inline for Is_Volatile * output.ads, output.adb (Write_Erase_Char): New procedure (Save/Restore_Output_Buffer): New procedures (Save/Restore_Output_Buffer): New procedures * sprint.ads, sprint.adb (Write_Itype): Handle case of record itypes Add missing support for anonymous access type (Write_Id): Insert calls to Write_Itype (Write_Itype): New procedure to output itypes * par-ch12.adb (P_Formal_Derived_Type_Definition): In Ada 2005, handle use of "limited" in declaration. * sinfo.ads, sinfo.adb: Formal derived types can carry an explicit "limited" indication. * sem_ch3.adb: Add with and use of Targparm. (Create_Component): If Frontend_Layout_On_Target is True and the copied component does not have a known static Esize, then reset the size and positional fields of the new component. (Analyze_Component_Declaration): A limited component is legal within a protected type that implements an interface. (Collect_Interfaces): Do not add to the list the interfaces that are implemented by the ancestors. (Derived_Type_Declaration): If the parent of the full-view is an interface perform a transformation of the tree to ensure that it has the same parent than the partial-view. This simplifies the job of the expander in order to generate the correct object layout, and it is needed because the list of interfaces of the full-view can be given in any order. (Process_Full_View): The parent of the full-view does not need to be a descendant of the parent of the partial view if both parents are interfaces. (Analyze_Private_Extension_Declaration): If declaration has an explicit "limited" the parent must be a limited type. (Build_Derived_Record_Type): A derived type that is explicitly limited must have limited ancestor and progenitors. (Build_Derived_Type): Ditto. (Process_Full_View): Verify that explicit uses of "limited" in partial and full declarations are consistent. (Find_Ancestor_Interface): Remove function. (Collect_Implemented_Interfaces): New procedure used to gather all implemented interfaces by a type. (Contain_Interface): New function used to check whether an interface is present in a list. (Find_Hidden_Interface): New function used to determine whether two lists of interfaces constitute a set equality. If not, the first differing interface is returned. (Process_Full_View): Improve the check for the "no hidden interface" rule as defined by AI-396. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@108295 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/ada')
-rw-r--r--gcc/ada/einfo.adb37
-rw-r--r--gcc/ada/einfo.ads15
-rw-r--r--gcc/ada/output.adb81
-rw-r--r--gcc/ada/output.ads53
-rw-r--r--gcc/ada/par-ch12.adb69
-rw-r--r--gcc/ada/sem_ch3.adb413
-rw-r--r--gcc/ada/sinfo.adb2
-rw-r--r--gcc/ada/sinfo.ads1532
-rw-r--r--gcc/ada/sprint.adb306
-rw-r--r--gcc/ada/sprint.ads1
10 files changed, 1585 insertions, 924 deletions
diff --git a/gcc/ada/einfo.adb b/gcc/ada/einfo.adb
index c126bd88e33..4a9eb8b8881 100644
--- a/gcc/ada/einfo.adb
+++ b/gcc/ada/einfo.adb
@@ -452,8 +452,8 @@ package body Einfo is
-- Is_Task_Interface Flag200
-- Has_Anon_Block_Suffix Flag201
+ -- Itype_Printed Flag202
- -- (unused) Flag202
-- (unused) Flag203
-- (unused) Flag204
-- (unused) Flag205
@@ -1877,6 +1877,7 @@ package body Einfo is
function Is_Volatile (Id : E) return B is
begin
pragma Assert (Nkind (Id) in N_Entity);
+
if Is_Type (Id) then
return Flag16 (Base_Type (Id));
else
@@ -1884,6 +1885,12 @@ package body Einfo is
end if;
end Is_Volatile;
+ function Itype_Printed (Id : E) return B is
+ begin
+ pragma Assert (Is_Itype (Id));
+ return Flag202 (Id);
+ end Itype_Printed;
+
function Kill_Elaboration_Checks (Id : E) return B is
begin
return Flag32 (Id);
@@ -4016,6 +4023,12 @@ package body Einfo is
Set_Flag16 (Id, V);
end Set_Is_Volatile;
+ procedure Set_Itype_Printed (Id : E; V : B := True) is
+ begin
+ pragma Assert (Is_Itype (Id));
+ Set_Flag202 (Id, V);
+ end Set_Itype_Printed;
+
procedure Set_Kill_Elaboration_Checks (Id : E; V : B := True) is
begin
Set_Flag32 (Id, V);
@@ -5722,6 +5735,7 @@ package body Einfo is
function Is_Limited_Type (Id : E) return B is
Btype : constant E := Base_Type (Id);
+ Rtype : constant E := Root_Type (Btype);
begin
if not Is_Type (Id) then
@@ -5744,11 +5758,17 @@ package body Einfo is
return False;
elsif Is_Record_Type (Btype) then
- if Is_Limited_Record (Root_Type (Btype)) then
- return True;
+
+ -- AI-419: limitedness is not inherited from a limited interface
+
+ if Is_Limited_Record (Rtype) then
+ return not Is_Interface (Rtype)
+ or else Is_Protected_Interface (Rtype)
+ or else Is_Synchronized_Interface (Rtype)
+ or else Is_Task_Interface (Rtype);
elsif Is_Class_Wide_Type (Btype) then
- return Is_Limited_Type (Root_Type (Btype));
+ return Is_Limited_Type (Rtype);
else
declare
@@ -5813,6 +5833,8 @@ package body Einfo is
-- Is_Return_By_Reference_Type --
---------------------------------
+ -- Note: this predicate has disappeared from Ada 2005: see AI-318-2
+
function Is_Return_By_Reference_Type (Id : E) return B is
Btype : constant Entity_Id := Base_Type (Id);
@@ -5820,7 +5842,6 @@ package body Einfo is
if Is_Private_Type (Btype) then
declare
Utyp : constant Entity_Id := Underlying_Type (Btype);
-
begin
if No (Utyp) then
return False;
@@ -5834,7 +5855,10 @@ package body Einfo is
elsif Is_Record_Type (Btype) then
if Is_Limited_Record (Btype) then
- return True;
+ return not Is_Interface (Btype)
+ or else Is_Protected_Interface (Btype)
+ or else Is_Synchronized_Interface (Btype)
+ or else Is_Task_Interface (Btype);
elsif Is_Class_Wide_Type (Btype) then
return Is_Return_By_Reference_Type (Root_Type (Btype));
@@ -6700,6 +6724,7 @@ package body Einfo is
W ("Is_Valued_Procedure", Flag127 (Id));
W ("Is_Visible_Child_Unit", Flag116 (Id));
W ("Is_Volatile", Flag16 (Id));
+ W ("Itype_Printed", Flag202 (Id));
W ("Kill_Elaboration_Checks", Flag32 (Id));
W ("Kill_Range_Checks", Flag33 (Id));
W ("Kill_Tag_Checks", Flag34 (Id));
diff --git a/gcc/ada/einfo.ads b/gcc/ada/einfo.ads
index fa1e5841674..290fd44c15d 100644
--- a/gcc/ada/einfo.ads
+++ b/gcc/ada/einfo.ads
@@ -2469,6 +2469,10 @@ package Einfo is
-- Present in package entities. Indicates that the package has been
-- created as a wrapper for a subprogram instantiation.
+-- Itype_Printed (Flag202)
+-- Set in Itypes if the Itype has been printed by Sprint. This is used to
+-- avoid printing an Itype more than once.
+
-- Kill_Elaboration_Checks (Flag32)
-- Present in all entities. Set by the expander to kill elaboration
-- checks which are known not to be needed. Equivalent in effect to
@@ -4166,6 +4170,7 @@ package Einfo is
-- Is_Tagged_Type (Flag55)
-- Is_Unsigned_Type (Flag144)
-- Is_Volatile (Flag16)
+ -- Itype_Printed (Flag202) (itypes only)
-- Must_Be_On_Byte_Boundary (Flag183)
-- Size_Depends_On_Discriminant (Flag177)
-- Size_Known_At_Compile_Time (Flag92)
@@ -5363,7 +5368,6 @@ package Einfo is
function Is_Potentially_Use_Visible (Id : E) return B;
function Is_Preelaborated (Id : E) return B;
function Is_Primitive_Wrapper (Id : E) return B;
-
function Is_Private_Composite (Id : E) return B;
function Is_Private_Descendant (Id : E) return B;
function Is_Protected_Interface (Id : E) return B;
@@ -5387,7 +5391,7 @@ package Einfo is
function Is_Valued_Procedure (Id : E) return B;
function Is_Visible_Child_Unit (Id : E) return B;
function Is_Volatile (Id : E) return B;
- function Is_Wrapper_Package (Id : E) return B;
+ function Itype_Printed (Id : E) return B;
function Kill_Elaboration_Checks (Id : E) return B;
function Kill_Range_Checks (Id : E) return B;
function Kill_Tag_Checks (Id : E) return B;
@@ -5567,6 +5571,7 @@ package Einfo is
function Is_Return_By_Reference_Type (Id : E) return B;
function Is_String_Type (Id : E) return B;
function Is_Task_Record_Type (Id : E) return B;
+ function Is_Wrapper_Package (Id : E) return B;
function Next_Component (Id : E) return E;
function Next_Discriminant (Id : E) return E;
function Next_Formal (Id : E) return E;
@@ -5890,6 +5895,7 @@ package Einfo is
procedure Set_Is_Valued_Procedure (Id : E; V : B := True);
procedure Set_Is_Visible_Child_Unit (Id : E; V : B := True);
procedure Set_Is_Volatile (Id : E; V : B := True);
+ procedure Set_Itype_Printed (Id : E; V : B := True);
procedure Set_Kill_Elaboration_Checks (Id : E; V : B := True);
procedure Set_Kill_Range_Checks (Id : E; V : B := True);
procedure Set_Kill_Tag_Checks (Id : E; V : B := True);
@@ -6445,7 +6451,6 @@ package Einfo is
pragma Inline (Is_Potentially_Use_Visible);
pragma Inline (Is_Preelaborated);
pragma Inline (Is_Primitive_Wrapper);
-
pragma Inline (Is_Private_Composite);
pragma Inline (Is_Private_Descendant);
pragma Inline (Is_Private_Type);
@@ -6477,6 +6482,7 @@ package Einfo is
pragma Inline (Is_VMS_Exception);
pragma Inline (Is_Valued_Procedure);
pragma Inline (Is_Visible_Child_Unit);
+ pragma Inline (Itype_Printed);
pragma Inline (Kill_Elaboration_Checks);
pragma Inline (Kill_Range_Checks);
pragma Inline (Kill_Tag_Checks);
@@ -6788,7 +6794,6 @@ package Einfo is
pragma Inline (Set_Is_Potentially_Use_Visible);
pragma Inline (Set_Is_Preelaborated);
pragma Inline (Set_Is_Primitive_Wrapper);
-
pragma Inline (Set_Is_Private_Composite);
pragma Inline (Set_Is_Private_Descendant);
pragma Inline (Set_Is_Protected_Interface);
@@ -6812,6 +6817,7 @@ package Einfo is
pragma Inline (Set_Is_Valued_Procedure);
pragma Inline (Set_Is_Visible_Child_Unit);
pragma Inline (Set_Is_Volatile);
+ pragma Inline (Set_Itype_Printed);
pragma Inline (Set_Kill_Elaboration_Checks);
pragma Inline (Set_Kill_Range_Checks);
pragma Inline (Set_Kill_Tag_Checks);
@@ -6909,6 +6915,7 @@ package Einfo is
-- access/set format that can be handled by xeinfo.
pragma Inline (Is_Package_Or_Generic_Package);
+ pragma Inline (Is_Volatile);
pragma Inline (Is_Wrapper_Package);
pragma Inline (Known_RM_Size);
pragma Inline (Known_Static_Component_Bit_Offset);
diff --git a/gcc/ada/output.adb b/gcc/ada/output.adb
index 0985743c8e3..e7e7ea04064 100644
--- a/gcc/ada/output.adb
+++ b/gcc/ada/output.adb
@@ -42,29 +42,6 @@ package body Output is
-- Record argument to last call to Set_Special_Output. If this is
-- non-null, then we are in special output mode.
- -------------------------
- -- Line Buffer Control --
- -------------------------
-
- -- Note: the following buffer and column position are maintained by
- -- the subprograms defined in this package, and are not normally
- -- directly modified or accessed by a client. However, a client is
- -- permitted to modify these values, using the knowledge that only
- -- Write_Eol actually generates any output.
-
- Buffer_Max : constant := 8192;
- Buffer : String (1 .. Buffer_Max + 1);
- -- Buffer used to build output line. We do line buffering because it
- -- is needed for the support of the debug-generated-code option (-gnatD).
- -- Historically it was first added because on VMS, line buffering is
- -- needed with certain file formats. So in any case line buffering must
- -- be retained for this purpose, even if other reasons disappear. Note
- -- any attempt to write more output to a line than can fit in the buffer
- -- will be silently ignored.
-
- Next_Column : Pos range 1 .. Buffer'Length + 1 := 1;
- -- Column about to be written
-
-----------------------
-- Local_Subprograms --
-----------------------
@@ -86,7 +63,7 @@ package body Output is
------------------
procedure Flush_Buffer is
- Len : constant Natural := Natural (Next_Column - 1);
+ Len : constant Natural := Next_Col - 1;
begin
if Len /= 0 then
@@ -111,7 +88,7 @@ package body Output is
else
Current_FD := Standerr;
- Next_Column := 1;
+ Next_Col := 1;
Write_Line ("fatal error: disk full");
OS_Exit (2);
end if;
@@ -119,7 +96,7 @@ package body Output is
-- Buffer is now empty
- Next_Column := 1;
+ Next_Col := 1;
end if;
end Flush_Buffer;
@@ -127,11 +104,34 @@ package body Output is
-- Column --
------------
- function Column return Nat is
+ function Column return Pos is
begin
- return Next_Column;
+ return Pos (Next_Col);
end Column;
+ ---------------------------
+ -- Restore_Output_Buffer --
+ ---------------------------
+
+ procedure Restore_Output_Buffer (S : Saved_Output_Buffer) is
+ begin
+ Next_Col := S.Next_Col;
+ Buffer (1 .. Next_Col - 1) := S.Buffer (1 .. Next_Col - 1);
+ end Restore_Output_Buffer;
+
+ ------------------------
+ -- Save_Output_Buffer --
+ ------------------------
+
+ function Save_Output_Buffer return Saved_Output_Buffer is
+ S : Saved_Output_Buffer;
+ begin
+ S.Buffer (1 .. Next_Col - 1) := Buffer (1 .. Next_Col - 1);
+ S.Next_Col := Next_Col;
+ Next_Col := 1;
+ return S;
+ end Save_Output_Buffer;
+
------------------------
-- Set_Special_Output --
------------------------
@@ -149,7 +149,7 @@ package body Output is
begin
if Special_Output_Proc = null then
Flush_Buffer;
- Next_Column := 1;
+ Next_Col := 1;
end if;
Current_FD := Standerr;
@@ -163,7 +163,7 @@ package body Output is
begin
if Special_Output_Proc = null then
Flush_Buffer;
- Next_Column := 1;
+ Next_Col := 1;
end if;
Current_FD := Standout;
@@ -236,12 +236,12 @@ package body Output is
procedure Write_Char (C : Character) is
begin
- if Next_Column = Buffer'Length then
+ if Next_Col = Buffer'Length then
Write_Eol;
end if;
- Buffer (Natural (Next_Column)) := C;
- Next_Column := Next_Column + 1;
+ Buffer (Next_Col) := C;
+ Next_Col := Next_Col + 1;
end Write_Char;
---------------
@@ -250,11 +250,22 @@ package body Output is
procedure Write_Eol is
begin
- Buffer (Natural (Next_Column)) := ASCII.LF;
- Next_Column := Next_Column + 1;
+ Buffer (Next_Col) := ASCII.LF;
+ Next_Col := Next_Col + 1;
Flush_Buffer;
end Write_Eol;
+ ----------------------
+ -- Write_Erase_Char --
+ ----------------------
+
+ procedure Write_Erase_Char (C : Character) is
+ begin
+ if Next_Col /= 1 and then Buffer (Next_Col - 1) = C then
+ Next_Col := Next_Col - 1;
+ end if;
+ end Write_Erase_Char;
+
---------------
-- Write_Int --
---------------
diff --git a/gcc/ada/output.ads b/gcc/ada/output.ads
index d69bcb3dcfb..10df6557844 100644
--- a/gcc/ada/output.ads
+++ b/gcc/ada/output.ads
@@ -6,7 +6,7 @@
-- --
-- S p e c --
-- --
--- Copyright (C) 1992-2005 Free Software Foundation, Inc. --
+-- Copyright (C) 1992-2005, 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- --
@@ -35,7 +35,8 @@
-- for writing error messages and informational output. It is also used
-- by the debug source file output routines (see Sprintf.Print_Eol).
-with Types; use Types;
+with Hostparm; use Hostparm;
+with Types; use Types;
package Output is
pragma Elaborate_Body;
@@ -86,6 +87,9 @@ package Output is
-- Write one character to the standard output file. Note that the
-- character should not be LF or CR (use Write_Eol for end of line)
+ procedure Write_Erase_Char (C : Character);
+ -- If last character in buffer matches C, erase it, otherwise no effect
+
procedure Write_Eol;
-- Write an end of line (whatever is required by the system in use,
-- e.g. CR/LF for DOS, or LF for Unix) to the standard output file.
@@ -106,11 +110,30 @@ package Output is
procedure Write_Line (S : String);
-- Equivalent to Write_Str (S) followed by Write_Eol;
- function Column return Nat;
+ function Column return Pos;
pragma Inline (Column);
-- Returns the number of the column about to be written (e.g. a value
-- of 1 means the current line is empty).
+ -------------------------
+ -- Buffer Save/Restore --
+ -------------------------
+
+ -- This facility allows the current line buffer to be saved and restored
+
+ type Saved_Output_Buffer is private;
+ -- Type used for Save/Restore_Buffer
+
+ Buffer_Max : constant := Hostparm.Max_Line_Length;
+ -- Maximal size of a buffered output line
+
+ function Save_Output_Buffer return Saved_Output_Buffer;
+ -- Save current line buffer and reset line buffer to empty
+
+ procedure Restore_Output_Buffer (S : Saved_Output_Buffer);
+ -- Restore previously saved output buffer. The value in S is not affected
+ -- so it is legtimate to restore a buffer more than once.
+
--------------------------
-- Debugging Procedures --
--------------------------
@@ -144,4 +167,28 @@ package Output is
procedure w (L : String; B : Boolean);
-- Dump contents of string followed by blank, Boolean, line return
+private
+ -- Note: the following buffer and column position are maintained by the
+ -- subprograms defined in this package, and cannot be directly modified or
+ -- accessed by a client.
+
+ Buffer : String (1 .. Buffer_Max + 1);
+ for Buffer'Alignment use 4;
+ -- Buffer used to build output line. We do line buffering because it
+ -- is needed for the support of the debug-generated-code option (-gnatD).
+ -- Historically it was first added because on VMS, line buffering is
+ -- needed with certain file formats. So in any case line buffering must
+ -- be retained for this purpose, even if other reasons disappear. Note
+ -- any attempt to write more output to a line than can fit in the buffer
+ -- will be silently ignored. The alignment clause improves the efficiency
+ -- of the save/restore procedures.
+
+ Next_Col : Positive range 1 .. Buffer'Length + 1 := 1;
+ -- Column about to be written
+
+ type Saved_Output_Buffer is record
+ Buffer : String (1 .. Buffer_Max + 1);
+ Next_Col : Positive;
+ end record;
+
end Output;
diff --git a/gcc/ada/par-ch12.adb b/gcc/ada/par-ch12.adb
index 49e18de7e52..cff5ac44fa1 100644
--- a/gcc/ada/par-ch12.adb
+++ b/gcc/ada/par-ch12.adb
@@ -519,6 +519,9 @@ package body Ch12 is
-- exception is ABSTRACT, where we have to scan ahead to see if we
-- have a formal derived type or a formal private type definition.
+ -- In addition, in Ada 2005 LIMITED may appear after abstract, so
+ -- that the lookahead must be extended by one more token.
+
when Tok_Abstract =>
Save_Scan_State (Scan_State);
Scan; -- past ABSTRACT
@@ -527,6 +530,18 @@ package body Ch12 is
Restore_Scan_State (Scan_State); -- to ABSTRACT
return P_Formal_Derived_Type_Definition;
+ elsif Token = Tok_Limited then
+ Scan; -- past LIMITED
+
+ if Token = Tok_New then
+ Restore_Scan_State (Scan_State); -- to ABSTRACT
+ return P_Formal_Derived_Type_Definition;
+
+ else
+ Restore_Scan_State (Scan_State); -- to ABSTRACT
+ return P_Formal_Private_Type_Definition;
+ end if;
+
else
Restore_Scan_State (Scan_State); -- to ABSTRACT
return P_Formal_Private_Type_Definition;
@@ -560,7 +575,25 @@ package body Ch12 is
Set_Limited_Present (Typedef_Node);
return Typedef_Node;
+ elsif Token = Tok_New then
+ Restore_Scan_State (Scan_State); -- to LIMITED
+ return P_Formal_Derived_Type_Definition;
+
else
+ if Token = Tok_Abstract then
+ Error_Msg_SC ("ABSTRACT must come before LIMITED");
+ Scan; -- past improper ABSTRACT
+
+ if Token = Tok_New then
+ Restore_Scan_State (Scan_State); -- to LIMITED
+ return P_Formal_Derived_Type_Definition;
+
+ else
+ Restore_Scan_State (Scan_State);
+ return P_Formal_Private_Type_Definition;
+ end if;
+ end if;
+
Restore_Scan_State (Scan_State);
return P_Formal_Private_Type_Definition;
end if;
@@ -666,6 +699,20 @@ package body Ch12 is
Scan; -- past LIMITED
end if;
+ if Token = Tok_Abstract then
+ if Prev_Token = Tok_Tagged then
+ Error_Msg_SC ("ABSTRACT must come before TAGGED");
+ elsif Prev_Token = Tok_Limited then
+ Error_Msg_SC ("ABSTRACT must come before LIMITED");
+ end if;
+
+ Resync_Past_Semicolon;
+
+ elsif Token = Tok_Tagged then
+ Error_Msg_SC ("TAGGED must come before LIMITED");
+ Resync_Past_Semicolon;
+ end if;
+
Set_Sloc (Def_Node, Token_Ptr);
T_Private;
return Def_Node;
@@ -676,9 +723,11 @@ package body Ch12 is
--------------------------------------------
-- FORMAL_DERIVED_TYPE_DEFINITION ::=
- -- [abstract] new SUBTYPE_MARK [[AND interface_list] with private]
+ -- [abstract] [limited]
+ -- new SUBTYPE_MARK [[AND interface_list] with private]
- -- The caller has checked the initial token(s) is/are NEW or ASTRACT NEW
+ -- The caller has checked the initial token(s) is/are NEW, ASTRACT NEW
+ -- LIMITED NEW, or ABSTRACT LIMITED NEW
-- Error recovery: cannot raise Error_Resync
@@ -693,6 +742,22 @@ package body Ch12 is
Scan; -- past ABSTRACT
end if;
+ if Token = Tok_Limited then
+ Set_Limited_Present (Def_Node);
+ Scan; -- past Limited
+
+ if Ada_Version < Ada_05 then
+ Error_Msg_SP
+ ("LIMITED in derived type is an Ada 2005 extension");
+ Error_Msg_SP
+ ("\unit must be compiled with -gnat05 switch");
+ end if;
+
+ if Token = Tok_Abstract then
+ Scan; -- past ABSTRACT. diagnosed already in caller.
+ end if;
+ end if;
+
Scan; -- past NEW;
Set_Subtype_Mark (Def_Node, P_Subtype_Mark);
No_Constraint;
diff --git a/gcc/ada/sem_ch3.adb b/gcc/ada/sem_ch3.adb
index a799427e013..d2442b44bad 100644
--- a/gcc/ada/sem_ch3.adb
+++ b/gcc/ada/sem_ch3.adb
@@ -65,6 +65,7 @@ with Sem_Warn; use Sem_Warn;
with Stand; use Stand;
with Sinfo; use Sinfo;
with Snames; use Snames;
+with Targparm; use Targparm;
with Tbuild; use Tbuild;
with Ttypes; use Ttypes;
with Uintp; use Uintp;
@@ -1416,6 +1417,7 @@ package body Sem_Ch3 is
elsif not Is_Derived_Type (Current_Scope)
and then not Is_Limited_Record (Current_Scope)
+ and then not Is_Concurrent_Type (Current_Scope)
then
Error_Msg_N
("nonlimited tagged type cannot have limited components", N);
@@ -2654,6 +2656,15 @@ package body Sem_Ch3 is
end if;
Build_Derived_Record_Type (N, Parent_Type, T);
+
+ if Limited_Present (N) then
+ Set_Is_Limited_Record (T);
+
+ if not Is_Limited_Type (Parent_Type) then
+ Error_Msg_NE ("parent type& of limited extension must be limited",
+ N, Parent_Type);
+ end if;
+ end if;
end Analyze_Private_Extension_Declaration;
---------------------------------
@@ -5703,8 +5714,12 @@ package body Sem_Ch3 is
-- are only specified for limited records. For completeness, these
-- flags are also initialized along with all the other flags below.
+ -- AI-419: limitedness is not inherited from an interface parent
+
Set_Is_Tagged_Type (Derived_Type, Is_Tagged);
- Set_Is_Limited_Record (Derived_Type, Is_Limited_Record (Parent_Type));
+ Set_Is_Limited_Record (Derived_Type,
+ Is_Limited_Record (Parent_Type)
+ and then not Is_Interface (Parent_Type));
-- STEP 2a: process discriminants of derived type if any
@@ -5887,7 +5902,9 @@ package body Sem_Ch3 is
Set_Is_Limited_Composite
(Derived_Type, Is_Limited_Composite (Parent_Type));
Set_Is_Limited_Record
- (Derived_Type, Is_Limited_Record (Parent_Type));
+ (Derived_Type,
+ Is_Limited_Record (Parent_Type)
+ and then not Is_Interface (Parent_Type));
Set_Is_Private_Composite
(Derived_Type, Is_Private_Composite (Parent_Type));
@@ -7646,7 +7663,7 @@ package body Sem_Ch3 is
end if;
end Add_Interface;
- -- Start of processing for Add_Interface
+ -- Start of processing for Collect_Interfaces
begin
pragma Assert (False
@@ -7682,29 +7699,6 @@ package body Sem_Ch3 is
Next (Intf);
end loop;
-
- -- A type extension may be written as a derivation from an interface.
- -- The completion will have to implement the same, or derive from a
- -- type that implements it as well.
-
- elsif Nkind (N) = N_Private_Extension_Declaration
- and then Is_Interface (Etype (Derived_Type))
- then
- Add_Interface (Etype (Derived_Type));
- end if;
-
- -- Same for task and protected types, that can derive directly from
- -- an interface (and implement additional interfaces that will be
- -- present in the interface list of the declaration).
-
- if Nkind (N) = N_Task_Type_Declaration
- or else Nkind (N) = N_Protected_Type_Declaration
- or else Nkind (N) = N_Single_Protected_Declaration
- or else Nkind (N) = N_Single_Task_Declaration
- then
- if Is_Interface (Etype (Derived_Type)) then
- Add_Interface (Etype (Derived_Type));
- end if;
end if;
end Collect_Interfaces;
@@ -9719,24 +9713,42 @@ package body Sem_Ch3 is
New_Compon : constant Entity_Id := New_Copy (Old_Compon);
begin
- -- Set the parent so we have a proper link for freezing etc. This
- -- is not a real parent pointer, since of course our parent does
- -- not own up to us and reference us, we are an illegitimate
- -- child of the original parent!
+ -- Set the parent so we have a proper link for freezing etc. This is
+ -- not a real parent pointer, since of course our parent does not own
+ -- up to us and reference us, we are an illegitimate child of the
+ -- original parent!
Set_Parent (New_Compon, Parent (Old_Compon));
+ -- If the old component's Esize was already determined and is a
+ -- static value, then the new component simply inherits it. Otherwise
+ -- the old component's size may require run-time determination, but
+ -- the new component's size still might be statically determinable
+ -- (if, for example it has a static constraint). In that case we want
+ -- Layout_Type to recompute the component's size, so we reset its
+ -- size and positional fields.
+
+ if Frontend_Layout_On_Target
+ and then not Known_Static_Esize (Old_Compon)
+ then
+ Set_Esize (New_Compon, Uint_0);
+ Init_Normalized_First_Bit (New_Compon);
+ Init_Normalized_Position (New_Compon);
+ Init_Normalized_Position_Max (New_Compon);
+ end if;
+
-- We do not want this node marked as Comes_From_Source, since
- -- otherwise it would get first class status and a separate
- -- cross-reference line would be generated. Illegitimate
- -- children do not rate such recognition.
+ -- otherwise it would get first class status and a separate cross-
+ -- reference line would be generated. Illegitimate children do not
+ -- rate such recognition.
Set_Comes_From_Source (New_Compon, False);
- -- But it is a real entity, and a birth certificate must be
- -- properly registered by entering it into the entity list.
+ -- But it is a real entity, and a birth certificate must be properly
+ -- registered by entering it into the entity list.
Enter_Name (New_Compon);
+
return New_Compon;
end Create_Component;
@@ -10749,6 +10761,13 @@ package body Sem_Ch3 is
if not Is_Interface (T) then
Error_Msg_NE ("(Ada 2005) & must be an interface", Intf, T);
+
+ elsif Limited_Present (Def)
+ and then not Is_Limited_Interface (T)
+ then
+ Error_Msg_NE
+ ("progenitor interface& of limited type must be limited",
+ N, T);
end if;
Next (Intf);
@@ -10782,6 +10801,100 @@ package body Sem_Ch3 is
return;
end if;
+ -- Ada 2005 (AI-251): The case in which the parent of the full-view is
+ -- an interface is special because the list of interfaces in the full
+ -- view can be given in any order. For example:
+
+ -- type A is interface;
+ -- type B is interface and A;
+ -- type D is new B with private;
+ -- private
+ -- type D is new A and B with null record; -- 1 --
+
+ -- In this case we perform the following transformation of -1-:
+
+ -- type D is new B and A with null record;
+
+ -- If the parent of the full-view covers the parent of the partial-view
+ -- we have two possible cases:
+
+ -- 1) They have the same parent
+ -- 2) The parent of the full-view implements some further interfaces
+
+ -- In both cases we do not need to perform the transformation. In the
+ -- first case the source program is correct and the transformation is
+ -- not needed; in the second case the source program does not fulfill
+ -- the no-hidden interfaces rule (AI-396) and the error will be reported
+ -- later.
+
+ -- This transformation not only simplifies the rest of the analysis of
+ -- this type declaration but also simplifies the correct generation of
+ -- the object layout to the expander.
+
+ if In_Private_Part (Current_Scope)
+ and then Is_Interface (Parent_Type)
+ then
+ declare
+ Iface : Node_Id;
+ Partial_View : Entity_Id;
+ Partial_View_Parent : Entity_Id;
+ New_Iface : Node_Id;
+
+ begin
+ -- Look for the associated private type declaration
+
+ Partial_View := First_Entity (Current_Scope);
+ loop
+ exit when not Present (Partial_View)
+ or else (Has_Private_Declaration (Partial_View)
+ and then Full_View (Partial_View) = T);
+
+ Next_Entity (Partial_View);
+ end loop;
+
+ -- If the partial view was not found then the source code has
+ -- errors and the transformation is not needed.
+
+ if Present (Partial_View) then
+ Partial_View_Parent := Etype (Partial_View);
+
+ -- If the parent of the full-view covers the parent of the
+ -- partial-view we have nothing else to do.
+
+ if Interface_Present_In_Ancestor
+ (Parent_Type, Partial_View_Parent)
+ then
+ null;
+
+ -- Traverse the list of interfaces of the full-view to look
+ -- for the parent of the partial-view and perform the tree
+ -- transformation.
+
+ else
+ Iface := First (Interface_List (Def));
+ while Present (Iface) loop
+ if Etype (Iface) = Etype (Partial_View) then
+ Rewrite (Subtype_Indication (Def),
+ New_Copy (Subtype_Indication
+ (Parent (Partial_View))));
+
+ New_Iface := Make_Identifier (Sloc (N),
+ Chars (Parent_Type));
+ Append (New_Iface, Interface_List (Def));
+
+ -- Analyze the transformed code
+
+ Derived_Type_Declaration (T, N, Is_Completion);
+ return;
+ end if;
+
+ Next (Iface);
+ end loop;
+ end if;
+ end if;
+ end;
+ end if;
+
-- Only composite types other than array types are allowed to have
-- discriminants.
@@ -10905,6 +11018,20 @@ package body Sem_Ch3 is
end if;
Build_Derived_Type (N, Parent_Type, T, Is_Completion);
+
+ -- AI-419: the parent type of an explicitly limited derived type must
+ -- be limited. Interface progenitors were checked earlier.
+
+ if Limited_Present (Def) then
+ Set_Is_Limited_Record (T);
+
+ if not Is_Limited_Type (Parent_Type)
+ and then not Is_Interface (Parent_Type)
+ then
+ Error_Msg_NE ("parent type& of limited type must be limited",
+ N, Parent_Type);
+ end if;
+ end if;
end Derived_Type_Declaration;
----------------------------------
@@ -13186,36 +13313,136 @@ package body Sem_Ch3 is
Full_Parent : Entity_Id;
Full_Indic : Node_Id;
- function Find_Ancestor_Interface
- (Typ : Entity_Id) return Entity_Id;
- -- Find an implemented interface in the derivation chain of Typ
+ procedure Collect_Implemented_Interfaces
+ (Typ : Entity_Id;
+ Ifaces : Elist_Id);
+ -- Ada 2005: Gather all the interfaces that Typ directly or
+ -- inherently implements. Duplicate entries are not added to
+ -- the list Ifaces.
+
+ function Contain_Interface
+ (Iface : Entity_Id;
+ Ifaces : Elist_Id) return Boolean;
+ -- Ada 2005: Determine whether Iface is present in the list Ifaces
+
+ function Find_Hidden_Interface
+ (Src : Elist_Id;
+ Dest : Elist_Id) return Entity_Id;
+ -- Ada 2005: Determine whether the interfaces in list Src are all
+ -- present in the list Dest. Return the first differing interface,
+ -- or Empty otherwise.
- -----------------------------
- -- Find_Ancestor_Interface --
- -----------------------------
+ ------------------------------------
+ -- Collect_Implemented_Interfaces --
+ ------------------------------------
- function Find_Ancestor_Interface
- (Typ : Entity_Id) return Entity_Id
+ procedure Collect_Implemented_Interfaces
+ (Typ : Entity_Id;
+ Ifaces : Elist_Id)
is
- T : Entity_Id;
+ Iface : Entity_Id;
+ Iface_Elmt : Elmt_Id;
begin
- T := Typ;
- while T /= Etype (T) loop
- if Is_Interface (Etype (T)) then
- return Etype (T);
- end if;
+ -- Implementations of the form:
+ -- type Typ is new Iface ...
- T := Etype (T);
+ if Is_Interface (Etype (Typ))
+ and then not Contain_Interface (Etype (Typ), Ifaces)
+ then
+ Append_Elmt (Etype (Typ), Ifaces);
+ end if;
- -- Protect us against erroneous code that has a large
- -- chain of circularity dependencies
+ -- Implementations of the form:
+ -- type Typ is ... and Iface ...
- exit when T = Typ;
- end loop;
+ if Present (Abstract_Interfaces (Typ)) then
+ Iface_Elmt := First_Elmt (Abstract_Interfaces (Typ));
+ while Present (Iface_Elmt) loop
+ Iface := Node (Iface_Elmt);
+
+ if Is_Interface (Iface)
+ and then not Contain_Interface (Iface, Ifaces)
+ then
+ Append_Elmt (Iface, Ifaces);
+ end if;
+
+ Next_Elmt (Iface_Elmt);
+ end loop;
+ end if;
+
+ -- Implementations of the form:
+ -- type Typ is new Parent_Typ and ...
+
+ if Ekind (Typ) = E_Record_Type
+ and then Present (Parent_Subtype (Typ))
+ then
+ Collect_Implemented_Interfaces (Parent_Subtype (Typ), Ifaces);
+
+ -- Implementations of the form:
+ -- type Typ is ... with private;
+
+ elsif Ekind (Typ) = E_Record_Type_With_Private
+ and then Present (Full_View (Typ))
+ and then Etype (Typ) /= Full_View (Typ)
+ and then Etype (Typ) /= Typ
+ then
+ Collect_Implemented_Interfaces (Etype (Typ), Ifaces);
+ end if;
+ end Collect_Implemented_Interfaces;
+
+ -----------------------
+ -- Contain_Interface --
+ -----------------------
+
+ function Contain_Interface
+ (Iface : Entity_Id;
+ Ifaces : Elist_Id) return Boolean
+ is
+ Iface_Elmt : Elmt_Id;
+
+ begin
+ if Present (Ifaces) then
+ Iface_Elmt := First_Elmt (Ifaces);
+ while Present (Iface_Elmt) loop
+ if Node (Iface_Elmt) = Iface then
+ return True;
+ end if;
+
+ Next_Elmt (Iface_Elmt);
+ end loop;
+ end if;
+
+ return False;
+ end Contain_Interface;
+
+ ---------------------------
+ -- Find_Hidden_Interface --
+ ---------------------------
+
+ function Find_Hidden_Interface
+ (Src : Elist_Id;
+ Dest : Elist_Id) return Entity_Id
+ is
+ Iface : Entity_Id;
+ Iface_Elmt : Elmt_Id;
+
+ begin
+ if Present (Src) and then Present (Dest) then
+ Iface_Elmt := First_Elmt (Src);
+ while Present (Iface_Elmt) loop
+ Iface := Node (Iface_Elmt);
+
+ if not Contain_Interface (Iface, Dest) then
+ return Iface;
+ end if;
+
+ Next_Elmt (Iface_Elmt);
+ end loop;
+ end if;
return Empty;
- end Find_Ancestor_Interface;
+ end Find_Hidden_Interface;
-- Start of processing for Process_Full_View
@@ -13255,49 +13482,28 @@ package body Sem_Ch3 is
Error_Msg_N ("generic type cannot have a completion", Full_T);
end if;
- -- Ada 2005 (AI-396): A full view shall be a descendant of an
- -- interface type if and only if the corresponding partial view
- -- (if any) is also a descendant of the interface type, or if
- -- the partial view is untagged.
-
if Ada_Version >= Ada_05
+ and then Is_Tagged_Type (Priv_T)
and then Is_Tagged_Type (Full_T)
then
declare
- Iface : Entity_Id;
- Iface_Def : Node_Id;
+ Iface : Entity_Id;
+ Priv_T_Ifaces : constant Elist_Id := New_Elmt_List;
+ Full_T_Ifaces : constant Elist_Id := New_Elmt_List;
begin
- Iface := Find_Ancestor_Interface (Full_T);
-
- if Present (Iface) then
- Iface_Def := Type_Definition (Parent (Iface));
-
- -- The full view derives from an interface descendant, but the
- -- partial view does not share the same tagged type.
+ Collect_Implemented_Interfaces (Priv_T, Priv_T_Ifaces);
+ Collect_Implemented_Interfaces (Full_T, Full_T_Ifaces);
- if Is_Tagged_Type (Priv_T)
- and then Etype (Priv_T) /= Etype (Full_T)
- and then Etype (Priv_T) /= Iface
- then
- Error_Msg_N ("(Ada 2005) tagged partial view cannot be " &
- "completed by a type that implements an " &
- "interface", Priv_T);
- end if;
+ -- Ada 2005 (AI-396): The partial view shall be a descendant of
+ -- an interface type if and only if the full view is a descendant
+ -- of the interface type.
- -- The full view derives from a limited, protected,
- -- synchronized or task interface descendant, but the
- -- partial view is not labeled as limited.
+ Iface := Find_Hidden_Interface (Full_T_Ifaces, Priv_T_Ifaces);
- if (Limited_Present (Iface_Def)
- or else Protected_Present (Iface_Def)
- or else Synchronized_Present (Iface_Def)
- or else Task_Present (Iface_Def))
- and then not Limited_Present (Parent (Priv_T))
- then
- Error_Msg_N ("(Ada 2005) non-limited private type cannot be "
- & "completed by a limited type", Priv_T);
- end if;
+ if Present (Iface) then
+ Error_Msg_NE ("interface & not implemented by partial view " &
+ "('R'M'-2005 7.3(9))", Full_T, Iface);
end if;
end;
end if;
@@ -13328,6 +13534,15 @@ package body Sem_Ch3 is
if Priv_Parent = Any_Type or else Full_Parent = Any_Type then
return;
+ -- Ada 2005 (AI-251): Interfaces in the full-typ can be given in
+ -- any order. Therefore we don't have to check that its parent must
+ -- be a descendant of the parent of the private type declaration.
+
+ elsif Is_Interface (Priv_Parent)
+ and then Is_Interface (Full_Parent)
+ then
+ null;
+
elsif not Is_Ancestor (Base_Type (Priv_Parent), Full_Parent) then
Error_Msg_N
("parent of full type must descend from parent"
@@ -13428,6 +13643,23 @@ package body Sem_Ch3 is
end if;
end if;
+ -- AI-419: verify that the use of "limited" is consistent
+
+ declare
+ Orig_Decl : constant Node_Id := Original_Node (N);
+ begin
+ if Nkind (Parent (Priv_T)) = N_Private_Extension_Declaration
+ and then not Limited_Present (Parent (Priv_T))
+ and then Nkind (Orig_Decl) = N_Full_Type_Declaration
+ and then Nkind
+ (Type_Definition (Orig_Decl)) = N_Derived_Type_Definition
+ and then Limited_Present (Type_Definition (Orig_Decl))
+ then
+ Error_Msg_N
+ ("full view of non-limited extension cannot be limited", N);
+ end if;
+ end;
+
-- Ada 2005 AI-363: if the full view has discriminants with
-- defaults, it is illegal to declare constrained access subtypes
-- whose designated type is the current type. This allows objects
@@ -14072,8 +14304,7 @@ package body Sem_Ch3 is
if Nkind (Parent (S)) /= N_Access_To_Object_Definition
and then not
(Nkind (Parent (S)) = N_Subtype_Declaration
- and then
- Is_Itype (Defining_Identifier (Parent (S))))
+ and then Is_Itype (Defining_Identifier (Parent (S))))
then
Check_Incomplete (Subtype_Mark (S));
end if;
diff --git a/gcc/ada/sinfo.adb b/gcc/ada/sinfo.adb
index 673d4541782..dc53ec01a8b 100644
--- a/gcc/ada/sinfo.adb
+++ b/gcc/ada/sinfo.adb
@@ -1692,6 +1692,7 @@ package body Sinfo is
begin
pragma Assert (False
or else NT (N).Nkind = N_Derived_Type_Definition
+ or else NT (N).Nkind = N_Formal_Derived_Type_Definition
or else NT (N).Nkind = N_Formal_Private_Type_Definition
or else NT (N).Nkind = N_Private_Extension_Declaration
or else NT (N).Nkind = N_Private_Type_Declaration
@@ -4278,6 +4279,7 @@ package body Sinfo is
begin
pragma Assert (False
or else NT (N).Nkind = N_Derived_Type_Definition
+ or else NT (N).Nkind = N_Formal_Derived_Type_Definition
or else NT (N).Nkind = N_Formal_Private_Type_Definition
or else NT (N).Nkind = N_Private_Extension_Declaration
or else NT (N).Nkind = N_Private_Type_Declaration
diff --git a/gcc/ada/sinfo.ads b/gcc/ada/sinfo.ads
index 60f8be32224..bf5edbc4e65 100644
--- a/gcc/ada/sinfo.ads
+++ b/gcc/ada/sinfo.ads
@@ -32,8 +32,8 @@
------------------------------------------------------------------------------
-- This package defines the structure of the abstract syntax tree. The Tree
--- package provides a basic tree structure. Sinfo describes how this
--- structure is used to represent the syntax of an Ada program.
+-- package provides a basic tree structure. Sinfo describes how this structure
+-- is used to represent the syntax of an Ada program.
-- Note: the grammar used here is taken from Version 5.95 of the RM, dated
-- November 1994. The grammar in the RM is followed very closely in the tree
@@ -43,12 +43,12 @@
-- program, but also the results of semantic analysis. In particular, the
-- nodes for defining identifiers, defining character literals and defining
-- operator symbols, collectively referred to as entities, represent what
--- would normally be regarded as the symbol table information. In addition
--- a number of the tree nodes contain semantic information.
+-- would normally be regarded as the symbol table information. In addition a
+-- number of the tree nodes contain semantic information.
--- WARNING: There is a C version of this package. Any changes to this
--- source file must be properly reflected in this C header file sinfo.h
--- which is created automatically from sinfo.ads using xsinfo.adb.
+-- WARNING: There is a C version of this package. Any changes to this source
+-- file must be properly reflected in this C header file sinfo.h which is
+-- created automatically from sinfo.ads using xsinfo.adb.
with Types; use Types;
with Uintp; use Uintp;
@@ -61,8 +61,8 @@ package Sinfo is
---------------------------------
-- If changes are made to this file, a number of related steps must be
- -- carried out to ensure consistency. First, if a field access function
- -- is added, it appears in seven places:
+ -- carried out to ensure consistency. First, if a field access function is
+ -- added, it appears in seven places:
-- The documentation associated with the node
-- The spec of the access function in sinfo.ads
@@ -72,9 +72,9 @@ package Sinfo is
-- The body of the set procedure in sinfo.adb
-- The pragma Inline at the end of sinfo.ads for the set procedure
- -- The field chosen must be consistent in all places, and, for a node
- -- that is a subexpression, must not overlap any of the standard
- -- expression fields.
+ -- The field chosen must be consistent in all places, and, for a node that
+ -- is a subexpression, must not overlap any of the standard expression
+ -- fields.
-- In addition, if any of the standard expression fields is changed, then
-- the utiliy program which creates the Treeprs spec (in file treeprs.ads)
@@ -99,52 +99,52 @@ package Sinfo is
-- Finally, four utility programs must be run:
- -- Run CSinfo to check that you have made the changes consistently.
- -- It checks most of the rules given above, with clear error messages.
- -- This utility reads sinfo.ads and sinfo.adb and generates a report
- -- to standard output.
+ -- Run CSinfo to check that you have made the changes consistently. It
+ -- checks most of the rules given above, with clear error messages. This
+ -- utility reads sinfo.ads and sinfo.adb and generates a report to
+ -- standard output.
-- Run XSinfo to create a-sinfo.h, the corresponding C header. This
- -- utility reads sinfo.ads and generates a-sinfo.h. Note that it
- -- does not need to read sinfo.adb, since the contents of the body
- -- are algorithmically determinable from the spec.
+ -- utility reads sinfo.ads and generates a-sinfo.h. Note that it does
+ -- not need to read sinfo.adb, since the contents of the body are
+ -- algorithmically determinable from the spec.
- -- Run XTreeprs to create treeprs.ads, an updated version of
- -- the module that is used to drive the tree print routine. This
- -- utility reads (but does not modify) treeprs.adt, the template
- -- that provides the basic structure of the file, and then fills
- -- in the data from the comments in sinfo.ads.
+ -- Run XTreeprs to create treeprs.ads, an updated version of the module
+ -- that is used to drive the tree print routine. This utility reads (but
+ -- does not modify) treeprs.adt, the template that provides the basic
+ -- structure of the file, and then fills in the data from the comments
+ -- in sinfo.ads.
- -- Run XNmake to create nmake.ads and nmake.adb, the package body
- -- and spec of the Nmake package which contains functions for
- -- constructing nodes.
+ -- Run XNmake to create nmake.ads and nmake.adb, the package body and
+ -- spec of the Nmake package which contains functions for constructing
+ -- nodes.
- -- Note: sometime we could write a utility that actually generated the
- -- body of sinfo from the spec instead of simply checking it, since, as
- -- noted above, the contents of the body can be determined from the spec.
+ -- Note: sometime we could write a utility that actually generated the body
+ -- of sinfo from the spec instead of simply checking it, since, as noted
+ -- above, the contents of the body can be determined from the spec.
--------------------------------
-- Implicit Nodes in the Tree --
--------------------------------
- -- Generally the structure of the tree very closely follows the grammar
- -- as defined in the RM. However, certain nodes are omitted to save
- -- space and simplify semantic processing. Two general classes of such
- -- omitted nodes are as follows:
+ -- Generally the structure of the tree very closely follows the grammar as
+ -- defined in the RM. However, certain nodes are omitted to save space and
+ -- simplify semantic processing. Two general classes of such omitted nodes
+ -- are as follows:
-- If the only possibilities for a non-terminal are one or more other
- -- non terminals (i.e. the rule is a "skinny" rule), then usually the
+ -- non-terminals (i.e. the rule is a "skinny" rule), then usually the
-- corresponding node is omitted from the tree, and the target construct
- -- appears directly. For example, a real type definition is either a
- -- floating point definition or a fixed point definition. No explicit
- -- node appears for real type definition. Instead either the floating
- -- point definition or fixed point definition appears directly.
+ -- appears directly. For example, a real type definition is either
+ -- floating point definition or a fixed point definition. No explicit node
+ -- appears for real type definition. Instead either the floating point
+ -- definition or fixed point definition appears directly.
-- If a non-terminal corresponds to a list of some other non-terminal
- -- (possibly with separating punctuation), then usually it is omitted
- -- from the tree, and a list of components appears instead. For
- -- example, sequence of statements does not appear explicitly in the
- -- tree. Instead a list of statements appears directly.
+ -- (possibly with separating punctuation), then usually it is omitted from
+ -- the tree, and a list of components appears instead. For example,
+ -- sequence of statements does not appear explicitly in the tree. Instead
+ -- a list of statements appears directly.
-- Some additional cases of omitted nodes occur and are documented
-- individually. In particular, many nodes are omitted in the tree
@@ -155,23 +155,22 @@ package Sinfo is
-------------------------------------------
-- In several declarative forms in the syntax, lists of defining
- -- identifiers appear (object declarations, component declarations,
- -- number declarations etc.)
+ -- identifiers appear (object declarations, component declarations, number
+ -- declarations etc.)
- -- The semantics of such statements are equivalent to a series of
- -- identical declarations of single defining identifiers (except that
- -- conformance checks require the same grouping of identifiers in the
- -- parameter case).
+ -- The semantics of such statements are equivalent to a series of identical
+ -- declarations of single defining identifiers (except that conformance
+ -- checks require the same grouping of identifiers in the parameter case).
-- To simplify semantic processing, the parser breaks down such multiple
-- declaration cases into sequences of single declarations, duplicating
- -- type and initialization information as required. The flags More_Ids
- -- and Prev_Ids are used to record the original form of the source in
- -- the case where the original source used a list of names, More_Ids
- -- being set on all but the last name and Prev_Ids being set on all
- -- but the first name. These flags are used to reconstruct the original
- -- source (e.g. in the Sprint package), and also are included in the
- -- conformance checks, but otherwise have no semantic significance.
+ -- type and initialization information as required. The flags More_Ids and
+ -- Prev_Ids are used to record the original form of the source in the case
+ -- where the original source used a list of names, More_Ids being set on
+ -- all but the last name and Prev_Ids being set on all but the first name.
+ -- These flags are used to reconstruct the original source (e.g. in the
+ -- Sprint package), and also are included in the conformance checks, but
+ -- otherwise have no semantic significance.
-- Note: the reason that we use More_Ids and Prev_Ids rather than
-- First_Name and Last_Name flags is so that the flags are off in the
@@ -182,20 +181,20 @@ package Sinfo is
-----------------------
-- With a few exceptions, if a construction of the form {non-terminal}
- -- appears in the tree, lists are used in the corresponding tree node
- -- (see package Nlists for handling of node lists). In this case a field
- -- of the parent node points to a list of nodes for the non-terminal. The
- -- field name for such fields has a plural name which always ends in "s".
- -- For example, a case statement has a field Alternatives pointing to a
- -- list of case statement alternative nodes.
+ -- appears in the tree, lists are used in the corresponding tree node (see
+ -- package Nlists for handling of node lists). In this case a field of the
+ -- parent node points to a list of nodes for the non-terminal. The field
+ -- name for such fields has a plural name which always ends in "s". For
+ -- example, a case statement has a field Alternatives pointing to list of
+ -- case statement alternative nodes.
- -- Only fields pointing to lists have names ending in "s", so generally
- -- the structure is strongly typed, fields not ending in s point to
- -- single nodes, and fields ending in s point to lists.
+ -- Only fields pointing to lists have names ending in "s", so generally the
+ -- structure is strongly typed, fields not ending in s point to single
+ -- nodes, and fields ending in s point to lists.
-- The following example shows how a traversal of a list is written. We
- -- suppose here that Stmt points to a N_Case_Statement node which has
- -- a list field called Alternatives:
+ -- suppose here that Stmt points to a N_Case_Statement node which has a
+ -- list field called Alternatives:
-- Alt := First (Alternatives (Stmt));
-- while Present (Alt) loop
@@ -205,8 +204,8 @@ package Sinfo is
-- Alt := Next (Alt);
-- end loop;
- -- The Present function tests for Empty, which in this case signals the
- -- end of the list. First returns Empty immediately if the list is empty.
+ -- The Present function tests for Empty, which in this case signals the end
+ -- of the list. First returns Empty immediately if the list is empty.
-- Present is defined in Atree, First and Next are defined in Nlists.
-- The exceptions to this rule occur with {DEFINING_IDENTIFIERS} in all
@@ -219,25 +218,25 @@ package Sinfo is
-- Pragmas --
-------------
- -- Pragmas can appear in many different context, but are not included
- -- in the grammar. Still they must appear in the tree, so they can be
- -- properly processed.
+ -- Pragmas can appear in many different context, but are not included in
+ -- the grammar. Still they must appear in the tree, so they can be properly
+ -- processed.
- -- Two approaches are used. In some cases, an extra field is defined
- -- in an appropriate node that contains a list of pragmas appearing
- -- in the expected context. For example pragmas can appear before an
+ -- Two approaches are used. In some cases, an extra field is defined in an
+ -- appropriate node that contains a list of pragmas appearing in the
+ -- expected context. For example pragmas can appear before an
-- Accept_Alternative in a Selective_Accept_Statement, and these pragmas
-- appear in the Pragmas_Before field of the N_Accept_Alternative node.
-- The other approach is to simply allow pragmas to appear in syntactic
-- lists where the grammar (of course) does not include the possibility.
- -- For example, the Variants field of an N_Variant_Part node points to
- -- a list that can contain both N_Pragma and N_Variant nodes.
+ -- For example, the Variants field of an N_Variant_Part node points to a
+ -- list that can contain both N_Pragma and N_Variant nodes.
-- To make processing easier in the latter case, the Nlists package
-- provides a set of routines (First_Non_Pragma, Last_Non_Pragma,
- -- Next_Non_Pragma, Prev_Non_Pragma) that allow such lists to be
- -- handled ignoring all pragmas.
+ -- Next_Non_Pragma, Prev_Non_Pragma) that allow such lists to be handled
+ -- ignoring all pragmas.
-- In the case of the variants list, we can either write:
@@ -255,30 +254,30 @@ package Sinfo is
-- Variant := Next_Non_Pragma (Variant);
-- end loop;
- -- In the first form of the loop, Variant can either be an N_Pragma or
- -- an N_Variant node. In the second form, Variant can only be N_Variant
- -- since all pragmas are skipped.
+ -- In the first form of the loop, Variant can either be an N_Pragma or an
+ -- N_Variant node. In the second form, Variant can only be N_Variant since
+ -- all pragmas are skipped.
---------------------
-- Optional Fields --
---------------------
-- Fields which correspond to a section of the syntax enclosed in square
- -- brackets are generally omitted (and the corresponding field set to
- -- Empty for a node, or No_List for a list). The documentation of such
- -- fields notes these cases. One exception to this rule occurs in the
- -- case of possibly empty statement sequences (such as the sequence of
- -- statements in an entry call alternative). Such cases appear in the
- -- syntax rules as [SEQUENCE_OF_STATEMENTS] and the fields corresponding
- -- to such optional statement sequences always contain an empty list (not
- -- No_List) if no statements are present.
-
- -- Note: the utility program that constructs the body and spec of the
- -- Nmake package relies on the format of the comments to determine if
- -- a field should have a default value in the corresponding make routine.
- -- The rule is that if the first line of the description of the field
- -- contains the string "(set to xxx if", then a default value of xxx is
- -- provided for this field in the corresponding Make_yyy routine.
+ -- brackets are generally omitted (and the corresponding field set to Empty
+ -- for a node, or No_List for a list). The documentation of such fields
+ -- notes these cases. One exception to this rule occurs in the case of
+ -- possibly empty statement sequences (such as the sequence of statements
+ -- in an entry call alternative). Such cases appear in the syntax rules as
+ -- [SEQUENCE_OF_STATEMENTS] and the fields corresponding to such optional
+ -- statement sequences always contain an empty list (not No_List) if no
+ -- statements are present.
+
+ -- Note: the utility program that constructs the body and spec of the Nmake
+ -- package relies on the format of the comments to determine if a field
+ -- should have a default value in the corresponding make routine. The rule
+ -- is that if the first line of the description of the field contains the
+ -- string "(set to xxx if", then a default value of xxx is provided for
+ -- this field in the corresponding Make_yyy routine.
-----------------------------------
-- Note on Body/Spec Terminology --
@@ -287,33 +286,33 @@ package Sinfo is
-- In informal discussions about Ada, it is customary to refer to package
-- and subprogram specs and bodies. However, this is not technically
-- correct, what is normally referred to as a spec or specification is in
- -- fact a package declaration or subprogram declaration. We are careful
- -- in GNAT to use the correct terminology and in particular, the full
- -- word specification is never used as an incorrect substitute for
- -- declaration. The structure and terminology used in the tree also
- -- reflects the grammar and thus uses declaration and specification in
- -- the technically correct manner.
-
- -- However, there are contexts in which the informal terminology is
- -- useful. We have the word "body" to refer to the Interp_Etype declared by
- -- the declaration of a unit body, and in some contexts we need a
- -- similar term to refer to the entity declared by the package or
- -- subprogram declaration, and simply using declaration can be confusing
- -- since the body also has a declaration.
-
- -- An example of such a context is the link between the package body
- -- and its declaration. With_Declaration is confusing, since
- -- the package body itself is a declaration.
-
- -- To deal with this problem, we reserve the informal term Spec, i.e.
- -- the popular abbreviation used in this context, to refer to the entity
+ -- fact a package declaration or subprogram declaration. We are careful in
+ -- GNAT to use the correct terminology and in particular, the full word
+ -- specification is never used as an incorrect substitute for declaration.
+ -- The structure and terminology used in the tree also reflects the grammar
+ -- and thus uses declaration and specification in the technically correct
+ -- manner.
+
+ -- However, there are contexts in which the informal terminology is useful.
+ -- We have the word "body" to refer to the Interp_Etype declared by the
+ -- declaration of a unit body, and in some contexts we need similar term to
+ -- refer to the entity declared by the package or subprogram declaration,
+ -- and simply using declaration can be confusing since the body also has a
+ -- declaration.
+
+ -- An example of such a context is the link between the package body and
+ -- its declaration. With_Declaration is confusing, since the package body
+ -- itself is a declaration.
+
+ -- To deal with this problem, we reserve the informal term Spec, i.e. the
+ -- popular abbreviation used in this context, to refer to the entity
-- declared by the package or subprogram declaration. So in the above
-- example case, the field in the body is called With_Spec.
-- Another important context for the use of the word Spec is in error
- -- messages, where a hyper-correct use of declaration would be confusing
- -- to a typical Ada programmer, and even for an expert programmer can
- -- cause confusion since the body has a declaration as well.
+ -- messages, where a hyper-correct use of declaration would be confusing to
+ -- a typical Ada programmer, and even for an expert programmer can cause
+ -- confusion since the body has a declaration as well.
-- So, to summarize:
@@ -340,8 +339,8 @@ package Sinfo is
-- Internal Use Nodes --
------------------------
- -- These are Node_Kind settings used in the internal implementation
- -- which are not logically part of the specification.
+ -- These are Node_Kind settings used in the internal implementation which
+ -- are not logically part of the specification.
-- N_Unused_At_Start
-- Completely unused entry at the start of the enumeration type. This
@@ -352,24 +351,24 @@ package Sinfo is
-- Completely unused entry at the end of the enumeration type. This is
-- handy so that arrays with Node_Kind as the index type have an extra
-- entry at the end (see for example the use of the Pchar_Pos_Array in
- -- Treepr, where the extra entry provides the limit value when dealing
- -- with the last used entry in the array).
+ -- Treepr, where the extra entry provides the limit value when dealing with
+ -- the last used entry in the array).
-----------------------------------------
-- Note on the settings of Sloc fields --
-----------------------------------------
- -- The Sloc field of nodes that come from the source is set by the
- -- parser. For internal nodes, and nodes generated during expansion
- -- the Sloc is usually set in the call to the constructor for the node.
- -- In general the Sloc value chosen for an internal node is the Sloc of
- -- the source node whose processing is responsible for the expansion. For
- -- example, the Sloc of an inherited primitive operation is the Sloc of
- -- the corresponding derived type declaration.
+ -- The Sloc field of nodes that come from the source is set by the parser.
+ -- For internal nodes, and nodes generated during expansion the Sloc is
+ -- usually set in the call to the constructor for the node. In general the
+ -- Sloc value chosen for an internal node is the Sloc of the source node
+ -- whose processing is responsible for the expansion. For example, the Sloc
+ -- of an inherited primitive operation is the Sloc of the corresponding
+ -- derived type declaration.
- -- For the nodes of a generic instantiation, the Sloc value is encoded
- -- to represent both the original Sloc in the generic unit, and the Sloc
- -- of the instantiation itself. See Sinput.ads for details.
+ -- For the nodes of a generic instantiation, the Sloc value is encoded to
+ -- represent both the original Sloc in the generic unit, and the Sloc of
+ -- the instantiation itself. See Sinput.ads for details.
-- Subprogram instances create two callable entities: one is the visible
-- subprogram instance, and the other is an anonymous subprogram nested
@@ -383,12 +382,12 @@ package Sinfo is
-- In the following node definitions, all fields, both syntactic and
-- semantic, are documented. The one exception is in the case of entities
- -- (defining indentifiers, character literals and operator symbols),
- -- where the usage of the fields depends on the entity kind. Entity
- -- fields are fully documented in the separate package Einfo.
+ -- (defining indentifiers, character literals and operator symbols), where
+ -- the usage of the fields depends on the entity kind. Entity fields are
+ -- fully documented in the separate package Einfo.
- -- In the node definitions, three common sets of fields are abbreviated
- -- to save both space in the documentation, and also space in the string
+ -- In the node definitions, three common sets of fields are abbreviated to
+ -- save both space in the documentation, and also space in the string
-- (defined in Tree_Print_Strings) used to print trees. The following
-- abbreviations are used:
@@ -427,15 +426,14 @@ package Sinfo is
-- Note: see under (EXPRESSION) for further details on the use of
-- the Paren_Count field to record the number of parentheses levels.
- -- Node_Kind is the type used in the Nkind field to indicate the node
- -- kind. The actual definition of this type is given later (the reason
- -- for this is that we want the descriptions ordered by logical chapter
- -- in the RM, but the type definition is reordered to facilitate the
- -- definition of some subtype ranges. The individual descriptions of
- -- the nodes show how the various fields are used in each node kind,
- -- as well as providing logical names for the fields. Functions and
- -- procedures are provided for accessing and setting these fields
- -- using these logical names.
+ -- Node_Kind is the type used in the Nkind field to indicate the node kind.
+ -- The actual definition of this type is given later (the reason for this
+ -- is that we want the descriptions ordered by logical chapter in the RM,
+ -- but the type definition is reordered to facilitate the definition of
+ -- some subtype ranges. The individual descriptions of the nodes show how
+ -- the various fields are used in each node kind, as well as providing
+ -- logical names for the fields. Functions and procedures are provided for
+ -- accessing and setting these fields using these logical names.
-----------------------
-- Gigi Restrictions --
@@ -458,118 +456,115 @@ package Sinfo is
-- The following flag fields appear in all nodes
-- Analyzed (Flag1)
- -- This flag is used to indicate that a node (and all its children
- -- have been analyzed. It is used to avoid reanalysis of a node that
- -- has already been analyzed, both for efficiency and functional
- -- correctness reasons.
+ -- This flag is used to indicate that a node (and all its children have
+ -- been analyzed. It is used to avoid reanalysis of a node that has
+ -- already been analyzed, both for efficiency and functional correctness
+ -- reasons.
-- Comes_From_Source (Flag2)
- -- This flag is on for any nodes built by the scanner or parser from
- -- the source program, and off for any nodes built by the analyzer or
+ -- This flag is on for any nodes built by the scanner or parser from the
+ -- source program, and off for any nodes built by the analyzer or
-- expander. It indicates that a node comes from the original source.
-- This flag is defined in Atree.
-- Error_Posted (Flag3)
- -- This flag is used to avoid multiple error messages being posted
- -- on or referring to the same node. This flag is set if an error
- -- message refers to a node or is posted on its source location,
- -- and has the effect of inhibiting further messages involving
- -- this same node.
+ -- This flag is used to avoid multiple error messages being posted on or
+ -- referring to the same node. This flag is set if an error message
+ -- refers to a node or is posted on its source location, and has the
+ -- effect of inhibiting further messages involving this same node.
-- Has_Dynamic_Length_Check (Flag10-Sem)
- -- This flag is present on all nodes. It is set to indicate that one
- -- of the routines in unit Checks has generated a length check action
- -- which has been inserted at the flagged node. This is used to avoid
- -- the generation of duplicate checks.
+ -- This flag is present on all nodes. It is set to indicate that one of
+ -- the routines in unit Checks has generated a length check action which
+ -- has been inserted at the flagged node. This is used to avoid the
+ -- generation of duplicate checks.
-- Has_Dynamic_Range_Check (Flag12-Sem)
- -- This flag is present on all nodes. It is set to indicate that one
- -- of the routines in unit Checks has generated a range check action
- -- which has been inserted at the flagged node. This is used to avoid
- -- the generation of duplicate checks.
+ -- This flag is present on all nodes. It is set to indicate that one of
+ -- the routines in unit Checks has generated a range check action which
+ -- has been inserted at the flagged node. This is used to avoid the
+ -- generation of duplicate checks.
------------------------------------
-- Description of Semantic Fields --
------------------------------------
- -- The meaning of the syntactic fields is generally clear from their
- -- names without any further description, since the names are chosen
- -- to correspond very closely to the syntax in the reference manual.
- -- This section describes the usage of the semantic fields, which are
- -- used to contain additional information determined during semantic
- -- analysis.
+ -- The meaning of the syntactic fields is generally clear from their names
+ -- without any further description, since the names are chosen to
+ -- correspond very closely to the syntax in the reference manual. This
+ -- section describes the usage of the semantic fields, which are used to
+ -- contain additional information determined during semantic analysis.
-- ABE_Is_Certain (Flag18-Sem)
- -- This flag is set in an instantiation node or a call node is
- -- determined to be sure to raise an ABE. This is used to trigger
- -- special handling of such cases, particularly in the instantiation
- -- case where we avoid instantiating the body if this flag is set.
- -- This flag is also present in an N_Formal_Package_Declaration_Node
- -- since formal package declarations are treated like instantiations,
- -- but it is always set to False in this context.
+ -- This flag is set in an instantiation node or a call node is determined
+ -- to be sure to raise an ABE. This is used to trigger special handling
+ -- of such cases, particularly in the instantiation case where we avoid
+ -- instantiating the body if this flag is set. This flag is also present
+ -- in an N_Formal_Package_Declaration_Node since formal package
+ -- declarations are treated like instantiations, but it is always set to
+ -- False in this context.
-- Accept_Handler_Records (List5-Sem)
- -- This field is present only in an N_Accept_Alternative node. It is
- -- used to temporarily hold the exception handler records from an
- -- accept statement in a selective accept. These exception handlers
- -- will eventually be placed in the Handler_Records list of the
- -- procedure built for this accept (see Expand_N_Selective_Accept
- -- procedure in Exp_Ch9 for further details).
+ -- This field is present only in an N_Accept_Alternative node. It is used
+ -- to temporarily hold the exception handler records from an accept
+ -- statement in a selective accept. These exception handlers will
+ -- eventually be placed in the Handler_Records list of the procedure
+ -- built for this accept (see Expand_N_Selective_Accept procedure in
+ -- Exp_Ch9 for further details).
-- Access_Types_To_Process (Elist2-Sem)
-- Present in N_Freeze_Entity nodes for Incomplete or private types.
- -- Contains the list of access types which may require specific
- -- treatment when the nature of the type completion is completely
- -- known. An example of such treatement is the generation of the
- -- associated_final_chain.
+ -- Contains the list of access types which may require specific treatment
+ -- when the nature of the type completion is completely known. An example
+ -- of such treatement is the generation of the associated_final_chain.
-- Actions (List1-Sem)
- -- This field contains a sequence of actions that are associated
- -- with the node holding the field. See the individual node types
- -- for details of how this field is used, as well as the description
- -- of the specific use for a particular node type.
+ -- This field contains a sequence of actions that are associated with the
+ -- node holding the field. See the individual node types for details of
+ -- how this field is used, as well as the description of the specific use
+ -- for a particular node type.
-- Activation_Chain_Entity (Node3-Sem)
-- This is used in tree nodes representing task activators (blocks,
-- subprogram bodies, package declarations, and task bodies). It is
-- initially Empty, and then gets set to point to the entity for the
-- declared Activation_Chain variable when the first task is declared.
- -- When tasks are declared in the corresponding declarative region
- -- this entity is located by name (its name is always _Chain) and
- -- the declared tasks are added to the chain.
+ -- When tasks are declared in the corresponding declarative region this
+ -- entity is located by name (its name is always _Chain) and the declared
+ -- tasks are added to the chain.
-- Acts_As_Spec (Flag4-Sem)
- -- A flag set in the N_Subprogram_Body node for a subprogram body
- -- which is acting as its own spec. This flag also appears in the
- -- compilation unit node at the library level for such a subprogram
- -- (see further description in spec of Lib package).
+ -- A flag set in the N_Subprogram_Body node for a subprogram body which
+ -- is acting as its own spec. This flag also appears in the compilation
+ -- unit node at the library level for such a subprogram (see further
+ -- description in spec of Lib package).
-- Actual_Designated_Subtype (Node2-Sem)
- -- Present in N_Free_Statement and N_Explicit_Dereference nodes. If
- -- GIGI needs to known the dynamic constrained subtype of the designated
+ -- Present in N_Free_Statement and N_Explicit_Dereference nodes. If gigi
+ -- needs to known the dynamic constrained subtype of the designated
-- object, this attribute is set to that type. This is done for
-- N_Free_Statements for access-to-classwide types and access to
- -- unconstrained packed array types, and for N_Explicit_Dereference
- -- when the designated type is an unconstrained packed array and the
+ -- unconstrained packed array types, and for N_Explicit_Dereference when
+ -- the designated type is an unconstrained packed array and the
-- dereference is the prefix of a 'Size attribute reference.
-- Aggregate_Bounds (Node3-Sem)
-- Present in array N_Aggregate nodes. If the aggregate contains
-- component associations this field points to an N_Range node whose
-- bounds give the lowest and highest discrete choice values. If the
- -- named aggregate contains a dynamic or null choice this field is
- -- empty. If the aggregate contains positional elements this field
- -- points to an N_Integer_Literal node giving the number of positional
- -- elements. Note that if the aggregate contains positional elements
- -- and an other choice the N_Integer_Literal only accounts for the
- -- number of positional elements.
+ -- named aggregate contains a dynamic or null choice this field is empty.
+ -- If the aggregate contains positional elements this field points to an
+ -- N_Integer_Literal node giving the number of positional elements. Note
+ -- that if the aggregate contains positional elements and an other choice
+ -- the N_Integer_Literal only accounts for the number of positional
+ -- elements.
-- All_Others (Flag11-Sem)
- -- Present in an N_Others_Choice node. This flag is set in the case
- -- of an others exception where all exceptions are to be caught, even
- -- those that are not normally handled (in particular the tasking abort
- -- signal). This is used for translation of the at end handler into
- -- a normal exception handler.
+ -- Present in an N_Others_Choice node. This flag is set in the case of an
+ -- others exception where all exceptions are to be caught, even those
+ -- that are not normally handled (in particular the tasking abort
+ -- signal). This is used for translation of the at end handler into a
+ -- normal exception handler.
-- Assignment_OK (Flag15-Sem)
-- This flag is set in a subexpression node for an object, indicating
@@ -580,37 +575,37 @@ package Sinfo is
-- limited type objects (such as tasks), setting discriminant fields,
-- setting tag values, etc. N_Object_Declaration nodes also have this
-- flag defined. Here it is used to indicate that an initialization
- -- expression is valid, even where it would normally not be allowed
- -- (e.g. where the type involved is limited).
+ -- expression is valid, even where it would normally not be allowed (e.g.
+ -- where the type involved is limited).
-- Associated_Node (Node4-Sem)
-- Present in nodes that can denote an entity: identifiers, character
-- literals, operator symbols, expanded names, operator nodes, and
- -- attribute reference nodes (all these nodes have an Entity field).
- -- This field is also present in N_Aggregate, N_Selected_Component,
- -- and N_Extension_Aggregate nodes. This field is used in generic
- -- processing to create links between the generic template and the
- -- generic copy. See Sem_Ch12.Get_Associated_Node for full details.
- -- Note that this field overlaps Entity, which is fine, since, as
- -- explained in Sem_Ch12, the normal function of Entity is not
- -- required at the point where the Associated_Node is set. Note
- -- also, that in generic templates, this means that the Entity field
- -- does not necessarily point to an Entity. Since the back end is
- -- expected to ignore generic templates, this is harmless.
+ -- attribute reference nodes (all these nodes have an Entity field). This
+ -- field is also present in N_Aggregate, N_Selected_Component, and
+ -- N_Extension_Aggregate nodes. This field is used in generic processing
+ -- to create links between the generic template and the generic copy. See
+ -- Sem_Ch12.Get_Associated_Node for full details. Note that this field
+ -- overlaps Entity, which is fine, since, as explained in Sem_Ch12, the
+ -- normal function of Entity is not required at the point where the
+ -- Associated_Node is set. Note also, that in generic templates, this
+ -- means that the Entity field does not necessarily point to an Entity.
+ -- Since the back end is expected to ignore generic templates, this is
+ -- harmless.
-- At_End_Proc (Node1)
- -- This field is present in an N_Handled_Sequence_Of_Statements node.
- -- It contains an identifier reference for the cleanup procedure to
- -- be called. See description of this node for further details.
+ -- This field is present in an N_Handled_Sequence_Of_Statements node. It
+ -- contains an identifier reference for the cleanup procedure to be
+ -- called. See description of this node for further details.
-- Backwards_OK (Flag6-Sem)
- -- A flag present in the N_Assignment_Statement node. It is used only
- -- if the type being assigned is an array type, and is set if analysis
+ -- A flag present in the N_Assignment_Statement node. It is used only if
+ -- the type being assigned is an array type, and is set if analysis
-- determines that it is definitely safe to do the copy backwards, i.e.
- -- starting at the highest addressed element. Note that if neither of
- -- the flags Forwards_OK or Backwards_OK is set, it means that the
- -- front end could not determine that either direction is definitely
- -- safe, and a runtime check is required.
+ -- starting at the highest addressed element. Note that if neither of the
+ -- flags Forwards_OK or Backwards_OK is set, it means that the front end
+ -- could not determine that either direction is definitely safe, and a
+ -- runtime check is required.
-- Body_To_Inline (Node3-Sem)
-- present in subprogram declarations. Denotes analyzed but unexpanded
@@ -621,68 +616,68 @@ package Sinfo is
-- which is used directly in later calls to the original subprogram.
-- Body_Required (Flag13-Sem)
- -- A flag that appears in the N_Compilation_Unit node indicating that
- -- the corresponding unit requires a body. For the package case, this
- -- indicates that a completion is required. In Ada 95, if the flag
- -- is not set for the package case, then a body may not be present.
- -- In Ada 83, if the flag is not set for the package case, then a
- -- body is optional. For a subprogram declaration, the flag is set
- -- except in the case where a pragma Import or Interface applies,
- -- in which case no body is permitted (in Ada 83 or Ada 95).
+ -- A flag that appears in the N_Compilation_Unit node indicating that the
+ -- corresponding unit requires a body. For the package case, this
+ -- indicates that a completion is required. In Ada 95, if the flag is not
+ -- set for the package case, then a body may not be present. In Ada 83,
+ -- if the flag is not set for the package case, then body is optional.
+ -- For a subprogram declaration, the flag is set except in the case where
+ -- a pragma Import or Interface applies, in which case no body is
+ -- permitted (in Ada 83 or Ada 95).
-- By_Ref (Flag5-Sem)
-- A flag present in the N_Return_Statement_Node. It is set when the
- -- returned expression is already allocated on the secondary stack
- -- and thus the result is passed by reference rather than copied
- -- another time.
+ -- returned expression is already allocated on the secondary stack and
+ -- thus the result is passed by reference rather than copied another
+ -- time.
-- Check_Address_Alignment (Flag11-Sem)
-- A flag present in N_Attribute_Definition clause for a 'Address
- -- attribute definition. This flag is set if a dynamic check should
- -- be generated at the freeze point for the entity to which this
- -- address clause applies. The reason that we need this flag is that
- -- we want to check for range checks being suppressed at the point
- -- where the attribute definition clause is given, rather than
- -- testing this at the freeze point.
+ -- attribute definition. This flag is set if a dynamic check should be
+ -- generated at the freeze point for the entity to which this address
+ -- clause applies. The reason that we need this flag is that we want to
+ -- check for range checks being suppressed at the point where the
+ -- attribute definition clause is given, rather than testing this at the
+ -- freeze point.
-- Compile_Time_Known_Aggregate (Flag18-Sem)
- -- Present in N_Aggregate nodes. Set for aggregates which can be
- -- fully evaluated at compile time without raising constraint error.
- -- Such aggregates can be passed as is to Gigi without any expansion.
- -- See Sem_Aggr for the specific conditions under which an aggregate
- -- has this flag set. See also the flag Static_Processing_OK.
+ -- Present in N_Aggregate nodes. Set for aggregates which can be fully
+ -- evaluated at compile time without raising constraint error. Such
+ -- aggregates can be passed as is to Gigi without any expansion. See
+ -- Sem_Aggr for the specific conditions under which an aggregate has this
+ -- flag set. See also the flag Static_Processing_OK.
-- Condition_Actions (List3-Sem)
- -- This field appears in else-if nodes and in the iteration scheme
- -- node for while loops. This field is only used during semantic
- -- processing to temporarily hold actions inserted into the tree.
- -- In the tree passed to gigi, the condition actions field is always
- -- set to No_List. For details on how this field is used, see the
- -- routine Insert_Actions in package Exp_Util, and also the expansion
- -- routines for the relevant nodes.
+ -- This field appears in else-if nodes and in the iteration scheme node
+ -- for while loops. This field is only used during semantic processing to
+ -- temporarily hold actions inserted into the tree. In the tree passed to
+ -- gigi, the condition actions field is always set to No_List. For
+ -- details on how this field is used, see the routine Insert_Actions in
+ -- package Exp_Util, and also the expansion routines for the relevant
+ -- nodes.
-- Controlling_Argument (Node1-Sem)
- -- This field is set in procedure and function call nodes if the call
- -- is a dispatching call (it is Empty for a non-dispatching call).
- -- It indicates the source of the controlling tag for the call. For
- -- Procedure calls, the Controlling_Argument is one of the actuals.
- -- For a function that has a dispatching result, it is an entity in
- -- the context of the call that can provide a tag, or else it is the
- -- tag of the root type of the class. It can also specify a tag
- -- directly rather than being a tagged object. The latter is needed
- -- by the implementations of AI-239 and AI-260.
+ -- This field is set in procedure and function call nodes if the call is
+ -- a dispatching call (it is Empty for a non-dispatching call). It
+ -- indicates the source of the call's controlling tag. For procedure
+ -- calls, the Controlling_Argument is one of the actuals. For function
+ -- that has a dispatching result, it is an entity in the context of the
+ -- call that can provide a tag, or else it is the tag of the root type of
+ -- the class. It can also specify a tag directly rather than being a
+ -- tagged object. The latter is needed by the implementations of AI-239
+ -- and AI-260.
-- Conversion_OK (Flag14-Sem)
- -- A flag set on type conversion nodes to indicate that the conversion
- -- is to be considered as being valid, even though it is the case that
- -- the conversion is not valid Ada. This is used for the Enum_Rep,
- -- Fixed_Value and Integer_Value attributes, for internal conversions
- -- done for fixed-point operations, and for certain conversions for
- -- calls to initialization procedures. If Conversion_OK is set, then
- -- Etype must be set (the analyzer assumes that Etype has been set).
- -- For the case of fixed-point operands, it also indicates that the
- -- conversion is to be a direct conversion of the underlying integer
- -- result, with no regard to the small operand.
+ -- A flag set on type conversion nodes to indicate that the conversion is
+ -- to be considered as being valid, even though it is the case that the
+ -- conversion is not valid Ada. This is used for Enum_Rep, Fixed_Value
+ -- and Integer_Value attributes, for internal conversions done for
+ -- fixed-point operations, and for certain conversions for calls to
+ -- initialization procedures. If Conversion_OK is set, then Etype must be
+ -- set (the analyzer assumes that Etype has been set). For the case of
+ -- fixed-point operands, it also indicates that the conversion is to be
+ -- direct conversion of the underlying integer result, with no regard to
+ -- the small operand.
-- Corresponding_Body (Node5-Sem)
-- This field is set in subprogram declarations, package declarations,
@@ -714,11 +709,11 @@ package Sinfo is
-- Corresponding_Spec (Node5-Sem)
-- This field is set in subprogram, package, task, and protected body
-- nodes, where it points to the defining entity in the corresponding
- -- spec. The attribute is also set in N_With_Clause nodes, where
- -- it points to the defining entity for the with'ed spec, and in
- -- a subprogram renaming declaration when it is a Renaming_As_Body.
- -- The field is Empty if there is no corresponding spec, as in the
- -- case of a subprogram body that serves as its own spec.
+ -- spec. The attribute is also set in N_With_Clause nodes, where it
+ -- points to the defining entity for the with'ed spec, and in a
+ -- subprogram renaming declaration when it is a Renaming_As_Body. The
+ -- field is Empty if there is no corresponding spec, as in the case of a
+ -- subprogram body that serves as its own spec.
-- Corresponding_Stub (Node3-Sem)
-- This field is present in an N_Subunit node. It holds the node in
@@ -732,29 +727,28 @@ package Sinfo is
-- for the discriminant checking function for the variant.
-- Debug_Statement (Node3)
- -- This field is present in an N_Pragma node. It is used only for
- -- a Debug pragma or pragma Assert with a second parameter. The
- -- parameter is of the form of an expression, as required by the
- -- pragma syntax, but is actually a procedure call. To simplify
+ -- This field is present in an N_Pragma node. It is used only for a Debug
+ -- pragma. The parameter is of the form of an expression, as required by
+ -- the pragma syntax, but is actually a procedure call. To simplify
-- semantic processing, the parser creates a copy of the argument
-- rearranged into a procedure call statement and places it in the
- -- Debug_Statement field. Note that this field is considered a
- -- syntactic field, since it is created by the parser.
+ -- Debug_Statement field. Note that this field is considered syntactic
+ -- field, since it is created by the parser.
-- Default_Expression (Node5-Sem)
- -- This field is Empty if there is no default expression. If there
- -- is a simple default expression (one with no side effects), then
- -- this field simply contains a copy of the Expression field (both
- -- point to the tree for the default expression). Default_Expression
- -- is used for conformance checking.
+ -- This field is Empty if there is no default expression. If there is a
+ -- simple default expression (one with no side effects), then this field
+ -- simply contains a copy of the Expression field (both point to the tree
+ -- for the default expression). Default_Expression is used for
+ -- conformance checking.
-- Delay_Finalize_Attach (Flag14-Sem)
-- This flag is present in an N_Object_Declaration node. If it is set,
-- then in the case of a controlled type being declared and initialized,
-- the normal code for attaching the result to the appropriate local
-- finalization list is suppressed. This is used for functions that
- -- return controlled types without using the secondary stack, where
- -- it is the caller who must do the attachment.
+ -- return controlled types without using the secondary stack, where it is
+ -- the caller who must do the attachment.
-- Discr_Check_Funcs_Built (Flag11-Sem)
-- This flag is present in N_Full_Type_Declaration nodes. It is set when
@@ -783,16 +777,16 @@ package Sinfo is
-- is required. It is not determined who deals with this flag (???).
-- Do_Overflow_Check (Flag17-Sem)
- -- This flag is set on an operator where an overflow check is required
- -- on the operation. The actual check is dealt with by the backend
- -- (all the front end does is to set the flag). The other cases where
- -- this flag is used is on a Type_Conversion node and for attribute
- -- reference nodes. For a type conversion, it means that the conversion
- -- is from one base type to another, and the value may not fit in the
- -- target base type. See also the description of Do_Range_Check for
- -- this case. The only attribute references which use this flag are
- -- Pred and Succ, where it means that the result should be checked
- -- for going outside the base range.
+ -- This flag is set on an operator where an overflow check is required on
+ -- the operation. The actual check is dealt with by the backend (all the
+ -- front end does is to set the flag). The other cases where this flag is
+ -- used is on a Type_Conversion node and for attribute reference nodes.
+ -- For a type conversion, it means that the conversion is from one base
+ -- type to another, and the value may not fit in the target base type.
+ -- See also the description of Do_Range_Check for this case. The only
+ -- attribute references which use this flag are Pred and Succ, where it
+ -- means that the result should be checked for going outside the base
+ -- range.
-- Do_Range_Check (Flag9-Sem)
-- This flag is set on an expression which appears in a context where
@@ -808,27 +802,27 @@ package Sinfo is
-- target type is determined from the type of the array, which is
-- referenced by the Prefix of the N_Indexed_Component node.
- -- Argument expression for a parameter, appearing either directly
- -- in the Parameter_Associations list of a call or as the Expression
- -- of an N_Parameter_Association node that appears in this list. In
- -- either case, the check is against the type of the formal. Note
- -- that the flag is relevant only in IN and IN OUT parameters, and
- -- will be ignored for OUT parameters, where no check is required
- -- in the call, and if a check is required on the return, it is
- -- generated explicitly with a type conversion.
+ -- Argument expression for a parameter, appearing either directly in
+ -- the Parameter_Associations list of a call or as the Expression of an
+ -- N_Parameter_Association node that appears in this list. In either
+ -- case, the check is against the type of the formal. Note that the
+ -- flag is relevant only in IN and IN OUT parameters, and will be
+ -- ignored for OUT parameters, where no check is required in the call,
+ -- and if a check is required on the return, it is generated explicitly
+ -- with a type conversion.
-- Initialization expression for the initial value in an object
-- declaration. In this case the Do_Range_Check flag is set on
-- the initialization expression, and the check is against the
-- range of the type of the object being declared.
- -- The expression of a type conversion. In this case the range check
- -- is against the target type of the conversion. See also the use of
- -- Do_Overflow_Check on a type conversion. The distinction is that
- -- the overflow check protects against a value that is outside the
- -- range of the target base type, whereas a range check checks that
- -- the resulting value (which is a value of the base type of the
- -- target type), satisfies the range constraint of the target type.
+ -- The expression of a type conversion. In this case the range check is
+ -- against the target type of the conversion. See also the use of
+ -- Do_Overflow_Check on a type conversion. The distinction is that the
+ -- overflow check protects against a value that is outside the range of
+ -- the target base type, whereas a range check checks that the
+ -- resulting value (which is a value of the base type of the target
+ -- type), satisfies the range constraint of the target type.
-- Note: when a range check is required in contexts other than those
-- listed above (e.g. in a return statement), an additional type
@@ -836,11 +830,11 @@ package Sinfo is
-- Do_Storage_Check (Flag17-Sem)
-- This flag is set in an N_Allocator node to indicate that a storage
- -- check is required for the allocation, or in an N_Subprogram_Body
- -- node to indicate that a stack check is required in the subprogram
- -- prolog. The N_Allocator case is handled by the routine that expands
- -- the call to the runtime routine. The N_Subprogram_Body case is
- -- handled by the backend, and all the semantics does is set the flag.
+ -- check is required for the allocation, or in an N_Subprogram_Body node
+ -- to indicate that a stack check is required in the subprogram prolog.
+ -- The N_Allocator case is handled by the routine that expands the call
+ -- to the runtime routine. The N_Subprogram_Body case is handled by the
+ -- backend, and all the semantics does is set the flag.
-- Do_Tag_Check (Flag13-Sem)
-- This flag is set on an N_Assignment_Statement, N_Function_Call,
@@ -879,10 +873,10 @@ package Sinfo is
-- actions at an appropriate place in the tree to get elaborated at the
-- right time. For conditional expressions, we have to be sure that the
-- actions for the Else branch are only elaborated if the condition is
- -- False. The Else_Actions field is used as a temporary parking place
- -- for these actions. The final tree is always rewritten to eliminate
- -- the need for this field, so in the tree passed to Gigi, this field
- -- is always set to No_List.
+ -- False. The Else_Actions field is used as a temporary parking place for
+ -- these actions. The final tree is always rewritten to eliminate the
+ -- need for this field, so in the tree passed to Gigi, this field is
+ -- always set to No_List.
-- Enclosing_Variant (Node2-Sem)
-- This field is present in the N_Variant node and identifies the
@@ -891,142 +885,137 @@ package Sinfo is
-- processing of the variant part of a record type.
-- Entity (Node4-Sem)
- -- Appears in all direct names (identifier, character literal,
- -- operator symbol), as well as expanded names, and attributes that
- -- denote entities, such as 'Class. Points to the entity for the
- -- corresponding defining occurrence. Set after name resolution.
- -- In the case of identifiers in a WITH list, the corresponding
- -- defining occurrence is in a separately compiled file, and this
- -- pointer must be set using the library Load procedure. Note that
- -- during name resolution, the value in Entity may be temporarily
- -- incorrect (e.g. during overload resolution, Entity is initially
- -- set to the first possible correct interpretation, and then later
- -- modified if necessary to contain the correct value after resolution).
- -- Note that this field overlaps Associated_Node, which is used during
- -- generic processing (see Sem_Ch12 for details). Note also that in
- -- generic templates, this means that the Entity field does not always
- -- point to an Entity. Since the back end is expected to ignore
- -- generic templates, this is harmless.
+ -- Appears in all direct names (identifier, character literal, operator
+ -- symbol), as well as expanded names, and attributes that denote
+ -- entities, such as 'Class. Points to the entity for the corresponding
+ -- defining occurrence. Set after name resolution. In the case of
+ -- identifiers in a WITH list, the corresponding defining occurrence is
+ -- in a separately compiled file, and this pointer must be set using the
+ -- library Load procedure. Note that during name resolution, the value in
+ -- Entity may be temporarily incorrect (e.g. during overload resolution,
+ -- Entity is initially set to the first possible correct interpretation,
+ -- and then later modified if necessary to contain the correct value
+ -- after resolution). Note that this field overlaps Associated_Node,
+ -- which is used during generic processing (see Sem_Ch12 for details).
+ -- Note also that in generic templates, this means that the Entity field
+ -- does not always point to an Entity. Since the back end is expected to
+ -- ignore generic templates, this is harmless.
-- Entity_Or_Associated_Node (Node4-Sem)
- -- A synonym for both Entity and Associated_Node. Used by convention
- -- in the code when referencing this field in cases where it is not
- -- known whether the field contains an Entity or an Associated_Node.
+ -- A synonym for both Entity and Associated_Node. Used by convention in
+ -- the code when referencing this field in cases where it is not known
+ -- whether the field contains an Entity or an Associated_Node.
-- Etype (Node5-Sem)
- -- Appears in all expression nodes, all direct names, and all
- -- entities. Points to the entity for the related type. Set after
- -- type resolution. Normally this is the actual subtype of the
- -- expression. However, in certain contexts such as the right side
- -- of an assignment, subscripts, arguments to calls, returned value
- -- in a function, initial value etc. it is the desired target type.
- -- In the event that this is different from the actual type, the
- -- Do_Range_Check flag will be set if a range check is required.
- -- Note: if the Is_Overloaded flag is set, then Etype points to
- -- an essentially arbitrary choice from the possible set of types.
+ -- Appears in all expression nodes, all direct names, and all entities.
+ -- Points to the entity for the related type. Set after type resolution.
+ -- Normally this is the actual subtype of the expression. However, in
+ -- certain contexts such as the right side of an assignment, subscripts,
+ -- arguments to calls, returned value in a function, initial value etc.
+ -- it is the desired target type. In the event that this is different
+ -- from the actual type, the Do_Range_Check flag will be set if a range
+ -- check is required. Note: if the Is_Overloaded flag is set, then Etype
+ -- points to an essentially arbitrary choice from the possible set of
+ -- types.
-- Exception_Junk (Flag7-Sem)
- -- This flag is set in a various nodes appearing in a statement
- -- sequence to indicate that the corresponding node is an artifact
- -- of the generated code for exception handling, and should be
- -- ignored when analyzing the control flow of the relevant sequence
- -- of statements (e.g. to check that it does not end with a bad
- -- return statement).
+ -- This flag is set in a various nodes appearing in a statement sequence
+ -- to indicate that the corresponding node is an artifact of the
+ -- generated code for exception handling, and should be ignored when
+ -- analyzing the control flow of the relevant sequence of statements
+ -- (e.g. to check that it does not end with a bad return statement).
-- Expansion_Delayed (Flag11-Sem)
- -- Set on aggregates and extension aggregates that need a top-down
- -- rather than bottom up expansion. Typically aggregate expansion
- -- happens bottom up. For nested aggregates the expansion is delayed
- -- until the enclosing aggregate itself is expanded, e.g. in the context
- -- of a declaration. To delay it we set this flag. This is done to
- -- avoid creating a temporary for each level of a nested aggregates,
- -- and also to prevent the premature generation of constraint checks.
- -- This is also a requirement if we want to generate the proper
- -- attachment to the internal finalization lists (for record with
- -- controlled components). Top down expansion of aggregates is also
- -- used for in-place array aggregate assignment or initialization.
- -- When the full context is known, the target of the assignment or
- -- initialization is used to generate the left-hand side of individual
- -- assignment to each sub-component.
+ -- Set on aggregates and extension aggregates that need a top-down rather
+ -- than bottom up expansion. Typically aggregate expansion happens bottom
+ -- up. For nested aggregates the expansion is delayed until the enclosing
+ -- aggregate itself is expanded, e.g. in the context of a declaration. To
+ -- delay it we set this flag. This is done to avoid creating a temporary
+ -- for each level of a nested aggregates, and also to prevent the
+ -- premature generation of constraint checks. This is also a requirement
+ -- if we want to generate the proper attachment to the internal
+ -- finalization lists (for record with controlled components). Top down
+ -- expansion of aggregates is also used for in-place array aggregate
+ -- assignment or initialization. When the full context is known, the
+ -- target of the assignment or initialization is used to generate the
+ -- left-hand side of individual assignment to each sub-component.
-- First_Inlined_Subprogram (Node3-Sem)
- -- Present in the N_Compilation_Unit node for the main program. Points
- -- to a chain of entities for subprograms that are to be inlined. The
+ -- Present in the N_Compilation_Unit node for the main program. Points to
+ -- a chain of entities for subprograms that are to be inlined. The
-- Next_Inlined_Subprogram field of these entities is used as a link
- -- pointer with Empty marking the end of the list. This field is Empty
- -- if there are no inlined subprograms or inlining is not active.
+ -- pointer with Empty marking the end of the list. This field is Empty if
+ -- there are no inlined subprograms or inlining is not active.
-- First_Named_Actual (Node4-Sem)
- -- Present in procedure call statement and function call nodes, and
- -- also in Intrinsic nodes. Set during semantic analysis to point to
- -- the first named parameter where parameters are ordered by declaration
- -- order (as opposed to the actual order in the call which may be
- -- different due to named associations). Note: this field points to the
- -- explicit actual parameter itself, not the N_Parameter_Association
- -- node (its parent).
+ -- Present in procedure call statement and function call nodes, and also
+ -- in Intrinsic nodes. Set during semantic analysis to point to the first
+ -- named parameter where parameters are ordered by declaration order (as
+ -- opposed to the actual order in the call which may be different due to
+ -- named associations). Note: this field points to the explicit actual
+ -- parameter itself, not the N_Parameter_Association node (its parent).
-- First_Real_Statement (Node2-Sem)
-- Present in N_Handled_Sequence_Of_Statements node. Normally set to
- -- Empty. Used only when declarations are moved into the statement
- -- part of a construct as a result of wrapping an AT END handler that
- -- is required to cover the declarations. In this case, this field is
- -- used to remember the location in the statements list of the first
- -- real statement, i.e. the statement that used to be first in the
- -- statement list before the declarations were prepended.
+ -- Empty. Used only when declarations are moved into the statement part
+ -- of a construct as a result of wrapping an AT END handler that is
+ -- required to cover the declarations. In this case, this field is used
+ -- to remember the location in the statements list of the first real
+ -- statement, i.e. the statement that used to be first in the statement
+ -- list before the declarations were prepended.
-- First_Subtype_Link (Node5-Sem)
- -- Present in N_Freeze_Entity node for an anonymous base type that
- -- is implicitly created by the declaration of a first subtype. It
- -- points to the entity for the first subtype.
+ -- Present in N_Freeze_Entity node for an anonymous base type that is
+ -- implicitly created by the declaration of a first subtype. It points to
+ -- the entity for the first subtype.
-- Float_Truncate (Flag11-Sem)
- -- A flag present in type conversion nodes. This is used for float
- -- to integer conversions where truncation is required rather than
- -- rounding. Note that Gigi does not handle type conversions from real
- -- to integer with rounding (see Expand_N_Type_Conversion).
+ -- A flag present in type conversion nodes. This is used for float to
+ -- integer conversions where truncation is required rather than rounding.
+ -- Note that Gigi does not handle type conversions from real to integer
+ -- with rounding (see Expand_N_Type_Conversion).
-- Forwards_OK (Flag5-Sem)
- -- A flag present in the N_Assignment_Statement node. It is used only
- -- if the type being assigned is an array type, and is set if analysis
+ -- A flag present in the N_Assignment_Statement node. It is used only if
+ -- the type being assigned is an array type, and is set if analysis
-- determines that it is definitely safe to do the copy forwards, i.e.
- -- starting at the lowest addressed element. Note that if neither of
- -- the flags Forwards_OK or Backwards_OK is set, it means that the
- -- front end could not determine that either direction is definitely
- -- safe, and a runtime check is required.
+ -- starting at the lowest addressed element. Note that if neither of the
+ -- flags Forwards_OK or Backwards_OK is set, it means that the front end
+ -- could not determine that either direction is definitely safe, and a
+ -- runtime check is required.
-- From_At_Mod (Flag4-Sem)
-- This flag is set on the attribute definition clause node that is
-- generated by a transformation of an at mod phrase in a record
- -- representation clause. This is used to give slightly different
- -- (Ada 83 compatible) semantics to such a clause, namely it is
- -- used to specify a minimum acceptable alignment for the base type
- -- and all subtypes. In Ada 95 terms, the actual alignment of the
- -- base type and all subtypes must be a multiple of the given value,
- -- and the representation clause is considered to be type specific
- -- instead of subtype specific.
+ -- representation clause. This is used to give slightly different (Ada 83
+ -- compatible) semantics to such a clause, namely it is used to specify a
+ -- minimum acceptable alignment for the base type and all subtypes. In
+ -- Ada 95 terms, the actual alignment of the base type and all subtypes
+ -- must be a multiple of the given value, and the representation clause
+ -- is considered to be type specific instead of subtype specific.
-- From_Default (Flag6-Sem)
- -- This flag is set on the subprogram renaming declaration created in
- -- an instance for a formal subprogram, when the formal is declared
- -- with a box, and there is no explicit actual. If the flag is present,
- -- the declaration is treated as an implicit reference to the formal in
- -- the ali file.
+ -- This flag is set on the subprogram renaming declaration created in an
+ -- instance for a formal subprogram, when the formal is declared with a
+ -- box, and there is no explicit actual. If the flag is present, the
+ -- declaration is treated as an implicit reference to the formal in the
+ -- ali file.
-- Generic_Parent (Node5-Sem)
- -- Generic_parent is defined on declaration nodes that are instances.
- -- The value of Generic_Parent is the generic entity from which the
- -- instance is obtained. Generic_Parent is also defined for the renaming
+ -- Generic_parent is defined on declaration nodes that are instances. The
+ -- value of Generic_Parent is the generic entity from which the instance
+ -- is obtained. Generic_Parent is also defined for the renaming
-- declarations and object declarations created for the actuals in an
-- instantiation. The generic parent of such a declaration is the
-- corresponding generic association in the Instantiation node.
-- Generic_Parent_Type (Node4-Sem)
- -- Generic_Parent_Type is defined on Subtype_Declaration nodes for
- -- the actuals of formal private and derived types. Within the instance,
- -- the operations on the actual are those inherited from the parent.
- -- For a formal private type, the parent type is the generic type
- -- itself. The Generic_Parent_Type is also used in an instance to
- -- determine whether a private operation overrides an inherited one.
+ -- Generic_Parent_Type is defined on Subtype_Declaration nodes for the
+ -- actuals of formal private and derived types. Within the instance, the
+ -- operations on the actual are those inherited from the parent. For a
+ -- formal private type, the parent type is the generic type itself. The
+ -- Generic_Parent_Type is also used in an instance to determine whether a
+ -- private operation overrides an inherited one.
-- Handler_List_Entry (Node2-Sem)
-- This field is present in N_Object_Declaration nodes. It is set only
@@ -1037,75 +1026,75 @@ package Sinfo is
-- this is required, see Exp_Ch11.Remove_Handler_Entries.
-- Has_No_Elaboration_Code (Flag17-Sem)
- -- A flag that appears in the N_Compilation_Unit node to indicate
- -- whether or not elaboration code is present for this unit. It is
- -- initially set true for subprogram specs and bodies and for all
- -- generic units and false for non-generic package specs and bodies.
- -- Gigi may set the flag in the non-generic package case if it
- -- determines that no elaboration code is generated. Note that this
- -- flag is not related to the Is_Preelaborated status, there can be
- -- preelaborated packages that generate elaboration code, and non-
- -- preelaborated packages which do not generate elaboration code.
+ -- A flag that appears in the N_Compilation_Unit node to indicate whether
+ -- or not elaboration code is present for this unit. It is initially set
+ -- true for subprogram specs and bodies and for all generic units and
+ -- false for non-generic package specs and bodies. Gigi may set the flag
+ -- in the non-generic package case if it determines that no elaboration
+ -- code is generated. Note that this flag is not related to the
+ -- Is_Preelaborated status, there can be preelaborated packages that
+ -- generate elaboration code, and non- preelaborated packages which do
+ -- not generate elaboration code.
-- Has_Priority_Pragma (Flag6-Sem)
-- A flag present in N_Subprogram_Body, N_Task_Definition and
- -- N_Protected_Definition nodes to flag the presence of either
- -- a Priority or Interrupt_Priority pragma in the declaration
- -- sequence (public or private in the task and protected cases)
+ -- N_Protected_Definition nodes to flag the presence of either a Priority
+ -- or Interrupt_Priority pragma in the declaration sequence (public or
+ -- private in the task and protected cases)
-- Has_Private_View (Flag11-Sem)
- -- A flag present in generic nodes that have an entity, to indicate
- -- that the node has a private type. Used to exchange private
- -- and full declarations if the visibility at instantiation is
- -- different from the visibility at generic definition.
+ -- A flag present in generic nodes that have an entity, to indicate that
+ -- the node has a private type. Used to exchange private and full
+ -- declarations if the visibility at instantiation is different from the
+ -- visibility at generic definition.
-- Has_Storage_Size_Pragma (Flag5-Sem)
- -- A flag present in an N_Task_Definition node to flag the presence
- -- of a Storage_Size pragma
+ -- A flag present in an N_Task_Definition node to flag the presence of a
+ -- Storage_Size pragma.
-- Has_Task_Info_Pragma (Flag7-Sem)
- -- A flag present in an N_Task_Definition node to flag the presence
- -- of a Task_Info pragma. Used to detect duplicate pragmas.
+ -- A flag present in an N_Task_Definition node to flag the presence of a
+ -- Task_Info pragma. Used to detect duplicate pragmas.
-- Has_Task_Name_Pragma (Flag8-Sem)
- -- A flag present in N_Task_Definition nodes to flag the presence
- -- of a Task_Name pragma in the declaration sequence for the task.
+ -- A flag present in N_Task_Definition nodes to flag the presence of a
+ -- Task_Name pragma in the declaration sequence for the task.
-- Has_Wide_Character (Flag11-Sem)
- -- Present in string literals, set if any wide character (i.e. a
- -- character code outside the Character range) appears in the string.
+ -- Present in string literals, set if any wide character (i.e. character
+ -- code outside the Character range) appears in the string.
-- Hidden_By_Use_Clause (Elist4-Sem)
-- An entity list present in use clauses that appear within
-- instantiations. For the resolution of local entities, entities
- -- introduced by these use clauses have priority over global ones,
- -- and outer entities must be explicitly hidden/restored on exit.
+ -- introduced by these use clauses have priority over global ones, and
+ -- outer entities must be explicitly hidden/restored on exit.
-- Implicit_With (Flag16-Sem)
-- This flag is set in the N_With_Clause node that is implicitly
- -- generated for runtime units that are loaded by the expander, and
- -- also for package System, if it is loaded implicitly by a use of
- -- the 'Address or 'Tag attribute
+ -- generated for runtime units that are loaded by the expander, and also
+ -- for package System, if it is loaded implicitly by a use of the
+ -- 'Address or 'Tag attribute.
-- Includes_Infinities (Flag11-Sem)
- -- This flag is present in N_Range nodes. It is set for the range
- -- of unconstrained float types defined in Standard, which include
- -- not only the given range of values, but also legtitimately can
- -- include infinite values. This flag is false for any float type
- -- for which an explicit range is given by the programmer, even if
- -- that range is identical to the range for float.
+ -- This flag is present in N_Range nodes. It is set for the range of
+ -- unconstrained float types defined in Standard, which include not only
+ -- the given range of values, but also legtitimately can include infinite
+ -- values. This flag is false for any float type for which an explicit
+ -- range is given by the programmer, even if that range is identical to
+ -- the range for Float.
-- Instance_Spec (Node5-Sem)
-- This field is present in generic instantiation nodes, and also in
-- formal package declaration nodes (formal package declarations are
- -- treated in a manner very similar to package instantiations). It
- -- points to the node for the spec of the instance, inserted as part
- -- of the semantic processing for instantiations in Sem_Ch12.
+ -- treated in a manner very similar to package instantiations). It points
+ -- to the node for the spec of the instance, inserted as part of the
+ -- semantic processing for instantiations in Sem_Ch12.
-- Is_Asynchronous_Call_Block (Flag7-Sem)
-- A flag set in a Block_Statement node to indicate that it is the
- -- expansion of an asynchronous entry call. Such a block needs a
- -- cleanup handler to assure that the call is cancelled.
+ -- expansion of an asynchronous entry call. Such a block needs cleanup
+ -- handler to assure that the call is cancelled.
-- Is_Component_Left_Opnd (Flag13-Sem)
-- Is_Component_Right_Opnd (Flag14-Sem)
@@ -1114,59 +1103,59 @@ package Sinfo is
-- concatenation nodes in instances.
-- Is_Controlling_Actual (Flag16-Sem)
- -- This flag is set on in an expression that is a controlling argument
- -- in a dispatching call. It is off in all other cases. See Sem_Disp
- -- for details of its use.
+ -- This flag is set on in an expression that is a controlling argument in
+ -- a dispatching call. It is off in all other cases. See Sem_Disp for
+ -- details of its use.
-- Is_In_Discriminant_Check (Flag11-Sem)
- -- This flag is present in a selected component, and is used to
- -- indicate that the reference occurs within a discriminant check.
- -- The significance is that optimizations based on assuming that
- -- the discriminant check has a correct value cannot be performed
- -- in this case (or the disriminant check may be optimized away!)
+ -- This flag is present in a selected component, and is used to indicate
+ -- that the reference occurs within a discriminant check. The
+ -- significance is that optimizations based on assuming that the
+ -- discriminant check has a correct value cannot be performed in this
+ -- case (or the disriminant check may be optimized away!)
-- Is_Machine_Number (Flag11-Sem)
- -- This flag is set in an N_Real_Literal node to indicate that the
- -- value is a machine number. This avoids some unnecessary cases
- -- of converting real literals to machine numbers.
+ -- This flag is set in an N_Real_Literal node to indicate that the value
+ -- is a machine number. This avoids some unnecessary cases of converting
+ -- real literals to machine numbers.
-- Is_Null_Loop (Flag16-Sem)
- -- This flag is set in an N_Loop_Statement node if the corresponding
- -- loop can be determined to be null at compile time. This is used to
- -- suppress any warnings that would otherwise be issued inside the
- -- loop since they are probably not useful.
+ -- This flag is set in an N_Loop_Statement node if the corresponding loop
+ -- can be determined to be null at compile time. This is used to suppress
+ -- any warnings that would otherwise be issued inside the loop since they
+ -- are probably not useful.
-- Is_Overloaded (Flag5-Sem)
-- A flag present in all expression nodes. Used temporarily during
- -- overloading determination. The setting of this flag is not
- -- relevant once overloading analysis is complete.
+ -- overloading determination. The setting of this flag is not relevant
+ -- once overloading analysis is complete.
-- Is_Power_Of_2_For_Shift (Flag13-Sem)
-- A flag present only in N_Op_Expon nodes. It is set when the
- -- exponentiation is of the forma 2 ** N, where the type of N is
- -- an unsigned integral subtype whose size does not exceed the size
- -- of Standard_Integer (i.e. a type that can be safely converted to
- -- Natural), and the exponentiation appears as the right operand of
- -- an integer multiplication or an integer division where the dividend
- -- is unsigned. It is also required that overflow checking is off for
- -- both the exponentiation and the multiply/divide node. If this set
- -- of conditions holds, and the flag is set, then the division or
+ -- exponentiation is of the forma 2 ** N, where the type of N is an
+ -- unsigned integral subtype whose size does not exceed the size of
+ -- Standard_Integer (i.e. a type that can be safely converted to
+ -- Natural), and the exponentiation appears as the right operand of an
+ -- integer multiplication or an integer division where the dividend is
+ -- unsigned. It is also required that overflow checking is off for both
+ -- the exponentiation and the multiply/divide node. If this set of
+ -- conditions holds, and the flag is set, then the division or
-- multiplication can be (and is) converted to a shift.
-- Is_Overloaded (Flag5-Sem)
-- A flag present in all expression nodes. Used temporarily during
- -- overloading determination. The setting of this flag is not
- -- relevant once overloading analysis is complete.
+ -- overloading determination. The setting of this flag is not relevant
+ -- once overloading analysis is complete.
-- Is_Protected_Subprogram_Body (Flag7-Sem)
-- A flag set in a Subprogram_Body block to indicate that it is the
- -- implemenation of a protected subprogram. Such a body needs a
- -- cleanup handler to make sure that the associated protected object
- -- is unlocked when the subprogram completes.
+ -- implemenation of a protected subprogram. Such a body needs cleanup
+ -- handler to make sure that the associated protected object is unlocked
+ -- when the subprogram completes.
-- Is_Static_Expression (Flag6-Sem)
- -- Indicates that an expression is a static expression (RM 4.9). See
- -- spec of package Sem_Eval for full details on the use of this flag.
+ -- Indicates that an expression is a static expression (RM 4.9). See spec
+ -- of package Sem_Eval for full details on the use of this flag.
-- Is_Subprogram_Descriptor (Flag16-Sem)
-- Present in N_Object_Declaration, and set only for the object
@@ -1181,19 +1170,19 @@ package Sinfo is
-- allocated but not activated when the allocator completes abnormally.
-- Is_Task_Master (Flag5-Sem)
- -- A flag set in a Subprogram_Body, Block_Statement or Task_Body node
- -- to indicate that the construct is a task master (i.e. has declared
- -- tasks or declares an access to a task type).
+ -- A flag set in a Subprogram_Body, Block_Statement or Task_Body node to
+ -- indicate that the construct is a task master (i.e. has declared tasks
+ -- or declares an access to a task type).
-- Itype (Node1-Sem)
- -- Used in N_Itype_Reference node to reference an itype for which it
- -- is important to ensure that it is defined. See description of this
- -- node for further details.
+ -- Used in N_Itype_Reference node to reference an itype for which it is
+ -- important to ensure that it is defined. See description of this node
+ -- for further details.
-- Kill_Range_Check (Flag11-Sem)
-- Used in an N_Unchecked_Type_Conversion node to indicate that the
- -- result should not be subjected to range checks. This is used for
- -- the implementation of Normalize_Scalars.
+ -- result should not be subjected to range checks. This is used for the
+ -- implementation of Normalize_Scalars.
-- Label_Construct (Node2-Sem)
-- Used in an N_Implicit_Label_Declaration node. Refers to an N_Label,
@@ -1202,36 +1191,35 @@ package Sinfo is
-- itself, but it is useful in the implementation of ASIS queries.
-- Library_Unit (Node4-Sem)
- -- In a stub node, the Library_Unit field points to the compilation unit
- -- node of the corresponding subunit.
+ -- In a stub node, Library_Unit points to the compilation unit node of
+ -- the corresponding subunit.
--
- -- In a with clause node, the Library_Unit field points to the spec
- -- of the with'ed unit.
+ -- In a with clause node, Library_Unit points to the spec of the with'ed
+ -- unit.
--
- -- In a compilation unit node, the use of this field depends on
- -- the unit type:
+ -- In a compilation unit node, the usage depends on the unit type:
--
- -- For a subprogram body, the Library_Unit field points to the
- -- compilation unit node of the corresponding spec, unless
- -- Acts_As_Spec is set, in which case it points to itself.
+ -- For a subprogram body, Library_Unit points to the compilation unit
+ -- node of the corresponding spec, unless Acts_As_Spec is set, in which
+ -- case it points to itself.
--
- -- For a package body, the Library_Unit field points to the
- -- compilation unit node of the corresponding spec.
+ -- For a package body, Library_Unit points to the compilation unit of
+ -- the corresponding package spec.
--
- -- For a subprogram spec to which pragma Inline applies, the
- -- Library_Unit field points to the compilation unit node of
- -- the corresponding body, if inlining is active.
+ -- For a subprogram spec to which pragma Inline applies, Library_Unit
+ -- points to the compilation unit node of the corresponding body, if
+ -- inlining is active.
--
- -- For a generic declaration, the Library_Unit field points
- -- to the compilation unit node of the corresponding generic body.
+ -- For a generic declaration, Library_Unit points to the compilation
+ -- unit node of the corresponding generic body.
--
- -- For a subunit, the Library_Unit field points to the compilation
- -- unit node of the parent body.
+ -- For a subunit, Library_Unit points to the compilation unit node of
+ -- the parent body.
--
- -- Note that this field is not used to hold the parent pointer for a
- -- child unit (which might in any case need to use it for some other
- -- purpose as described above). Instead for a child unit, implicit
- -- with's are generated for all parents.
+ -- Note that this field is not used to hold the parent pointer for child
+ -- unit (which might in any case need to use it for some other purpose as
+ -- described above). Instead for a child unit, implicit with's are
+ -- generated for all parents.
-- Loop_Actions (List2-Sem)
-- A list present in Component_Association nodes in array aggregates.
@@ -1239,76 +1227,75 @@ package Sinfo is
-- they may need to be evaluated anew each time through.
-- Limited_View_Installed (Flag18-Sem)
- -- Present in With_Clauses and in package specifications. If set on a
+ -- Present in With_Clauses and in package specifications. If set on
-- with_clause, it indicates that this clause has created the current
- -- limited view of the designated package. On a package specification,
- -- it indicates that the limited view has already been created because
- -- the package is mentioned in a limited_with_clause in the closure of
- -- the unit being compiled.
+ -- limited view of the designated package. On a package specification, it
+ -- indicates that the limited view has already been created because the
+ -- package is mentioned in a limited_with_clause in the closure of the
+ -- unit being compiled.
-- Must_Be_Byte_Aligned (Flag14-Sem)
-- This flag is present in N_Attribute_Reference nodes. It can be set
-- only for the Address and Unrestricted_Access attributes. If set it
- -- means that the object for which the address/access is given must be
- -- on a byte (more accurately a storage unit) boundary. If necessary,
- -- a copy of the object is to be made before taking the address (this
- -- copy is in the current scope on the stack frame). This is used for
- -- certain cases of code generated by the expander that passes
- -- parameters by address.
+ -- means that the object for which the address/access is given must be on
+ -- a byte (more accurately a storage unit) boundary. If necessary, a copy
+ -- of the object is to be made before taking the address (this copy is in
+ -- the current scope on the stack frame). This is used for certain cases
+ -- of code generated by the expander that passes parameters by address.
--
- -- The reason the copy is not made by the front end is that the back
- -- end has more information about type layout and may be able to (but
- -- is not guaranteed to) prevent making unnecessary copies.
+ -- The reason the copy is not made by the front end is that the back end
+ -- has more information about type layout and may be able to (but is not
+ -- guaranteed to) prevent making unnecessary copies.
-- Must_Not_Freeze (Flag8-Sem)
-- A flag present in all expression nodes. Normally expressions cause
- -- freezing as described in the RM. If this flag is set, then this
- -- is inhibited. This is used by the analyzer and expander to label
- -- nodes that are created by semantic analysis or expansion and which
- -- must not cause freezing even though they normally would. This flag
- -- is also present in an N_Subtype_Indication node, since we also use
- -- these in calls to Freeze_Expression.
+ -- freezing as described in the RM. If this flag is set, then this is
+ -- inhibited. This is used by the analyzer and expander to label nodes
+ -- that are created by semantic analysis or expansion and which must not
+ -- cause freezing even though they normally would. This flag is also
+ -- present in an N_Subtype_Indication node, since we also use these in
+ -- calls to Freeze_Expression.
-- Next_Entity (Node2-Sem)
-- Present in defining identifiers, defining character literals and
- -- defining operator symbols (i.e. in all entities). The entities of
- -- a scope are chained, and this field is used as the forward pointer
- -- for this list. See Einfo for further details.
+ -- defining operator symbols (i.e. in all entities). The entities of a
+ -- scope are chained, and this field is used as the forward pointer for
+ -- this list. See Einfo for further details.
-- Next_Named_Actual (Node4-Sem)
- -- Present in parameter association node. Set during semantic
- -- analysis to point to the next named parameter, where parameters
- -- are ordered by declaration order (as opposed to the actual order
- -- in the call, which may be different due to named associations).
- -- Not that this field points to the explicit actual parameter itself,
- -- not to the N_Parameter_Association node (its parent).
+ -- Present in parameter association node. Set during semantic analysis to
+ -- point to the next named parameter, where parameters are ordered by
+ -- declaration order (as opposed to the actual order in the call, which
+ -- may be different due to named associations). Not that this field
+ -- points to the explicit actual parameter itself, not to the
+ -- N_Parameter_Association node (its parent).
-- Next_Rep_Item (Node4-Sem)
- -- Present in pragma nodes and attribute definition nodes. Used to
- -- link representation items that apply to an entity. See description
- -- of First_Rep_Item field in Einfo for full details.
+ -- Present in pragma nodes and attribute definition nodes. Used to link
+ -- representation items that apply to an entity. See description of
+ -- First_Rep_Item field in Einfo for full details.
-- Next_Use_Clause (Node3-Sem)
- -- While use clauses are active during semantic processing, they
- -- are chained from the scope stack entry, using Next_Use_Clause
- -- as a link pointer, with Empty marking the end of the list. The
- -- head pointer is in the scope stack entry (First_Use_Clause). At
- -- the end of semantic processing (i.e. when Gigi sees the tree,
- -- the contents of this field is undefined and should not be read).
+ -- While use clauses are active during semantic processing, they are
+ -- chained from the scope stack entry, using Next_Use_Clause as a link
+ -- pointer, with Empty marking the end of the list. The head pointer is
+ -- in the scope stack entry (First_Use_Clause). At the end of semantic
+ -- processing (i.e. when Gigi sees the tree, the contents of this field
+ -- is undefined and should not be read).
-- No_Ctrl_Actions (Flag7-Sem)
- -- Present in N_Assignment_Statement to indicate that no finalize nor
- -- nor adjust should take place on this assignment eventhough the rhs
- -- is controlled. This is used in init procs and aggregate expansions
- -- where the generated assignments are more initialisations than real
+ -- Present in N_Assignment_Statement to indicate that no finalize nor nor
+ -- adjust should take place on this assignment eventhough the rhs is
+ -- controlled. This is used in init procs and aggregate expansions where
+ -- the generated assignments are more initialisations than real
-- assignments.
-- No_Elaboration_Check (Flag14-Sem)
-- Present in N_Function_Call and N_Procedure_Call_Statement. Indicates
- -- that no elaboration check is needed on the call, because it appears
- -- in the context of a local Suppress pragma. This is used on calls
- -- within task bodies, where the actual elaboration checks are applied
- -- after analysis, when the local scope stack is not present.
+ -- that no elaboration check is needed on the call, because it appears in
+ -- the context of a local Suppress pragma. This is used on calls within
+ -- task bodies, where the actual elaboration checks are applied after
+ -- analysis, when the local scope stack is not present.
-- No_Entities_Ref_In_Spec (Flag8-Sem)
-- Present in N_With_Clause nodes. Set if the with clause is on the
@@ -1319,12 +1306,12 @@ package Sinfo is
-- full details)
-- No_Initialization (Flag13-Sem)
- -- Present in N_Object_Declaration & N_Allocator to indicate
- -- that the object must not be initialized (by Initialize or a
- -- call to an init proc). This is needed for controlled aggregates.
- -- When the Object declaration has an expression, this flag means
- -- that this expression should not be taken into account (needed
- -- for in place initialization with aggregates)
+ -- Present in N_Object_Declaration & N_Allocator to indicate that the
+ -- object must not be initialized (by Initialize or call to an init
+ -- proc). This is needed for controlled aggregates. When the Object
+ -- declaration has an expression, this flag means that this expression
+ -- should not be taken into account (needed for in place initialization
+ -- with aggregates)
-- No_Truncation (Flag17-Sem)
-- Present in N_Unchecked_Type_Conversion node. This flag has an effect
@@ -1332,51 +1319,51 @@ package Sinfo is
-- target for scalar operands. Normally in such a case we truncate some
-- higher order bits of the source, and then sign/zero extend the result
-- to form the output value. But if this flag is set, then we do not do
- -- any truncation, so for example, if an 8 bit input is converted to a
- -- 5 bit result which is in fact stored in 8 bits, then the high order
+ -- any truncation, so for example, if an 8 bit input is converted to 5
+ -- bit result which is in fact stored in 8 bits, then the high order
-- three bits of the target result will be copied from the source. This
-- is used for properly setting out of range values for use by pragmas
-- Initialize_Scalars and Normalize_Scalars.
-- Original_Discriminant (Node2-Sem)
-- Present in identifiers. Used in references to discriminants that
- -- appear in generic units. Because the names of the discriminants
- -- may be different in an instance, we use this field to recover the
- -- position of the discriminant in the original type, and replace it
- -- with the discriminant at the same position in the instantiated type.
+ -- appear in generic units. Because the names of the discriminants may be
+ -- different in an instance, we use this field to recover the position of
+ -- the discriminant in the original type, and replace it with the
+ -- discriminant at the same position in the instantiated type.
-- Original_Entity (Node2-Sem)
- -- Present in numeric literals. Used to denote the named number that
- -- has been constant-folded into the given literal. If literal is from
+ -- Present in numeric literals. Used to denote the named number that has
+ -- been constant-folded into the given literal. If literal is from
-- source, or the result of some other constant-folding operation, then
-- Original_Entity is empty. This field is needed to handle properly
-- named numbers in generic units, where the Associated_Node field
- -- interferes with the Entity field, making it impossible to preserve
- -- the original entity at the point of instantiation (ASIS problem).
+ -- interferes with the Entity field, making it impossible to preserve the
+ -- original entity at the point of instantiation (ASIS problem).
-- Others_Discrete_Choices (List1-Sem)
-- When a case statement or variant is analyzed, the semantic checks
-- determine the actual list of choices that correspond to an others
- -- choice. This list is materialized for later use by the expander
- -- and the Others_Discrete_Choices field of an N_Others_Choice node
- -- points to this materialized list of choices, which is in standard
- -- format for a list of discrete choices, except that of course it
- -- cannot contain an N_Others_Choice entry.
+ -- choice. This list is materialized for later use by the expander and
+ -- the Others_Discrete_Choices field of an N_Others_Choice node points to
+ -- this materialized list of choices, which is in standard format for a
+ -- list of discrete choices, except that of course it cannot contain an
+ -- N_Others_Choice entry.
-- Parameter_List_Truncated (Flag17-Sem)
- -- Present in N_Function_Call and N_Procedure_Call_Statement nodes.
- -- Set (for OpenVMS ports of GNAT only) if the parameter list is
- -- truncated as a result of a First_Optional_Parameter specification
- -- in an Import_Function, Import_Procedure, or Import_Valued_Procedure
- -- pragma. The truncation is done by the expander by removing trailing
- -- parameters from the argument list, in accordance with the set of
- -- rules allowing such parameter removal. In particular, parameters
- -- can be removed working from the end of the parameter list backwards
- -- up to and including the entry designated by First_Optional_Parameter
- -- in the Import pragma. Parameters can be removed if they are implicit
- -- and the default value is a known-at-compile-time value, including
- -- the use of the Null_Parameter attribute, or if explicit parameter
- -- values are present that match the corresponding defaults.
+ -- Present in N_Function_Call and N_Procedure_Call_Statement nodes. Set
+ -- (for OpenVMS ports of GNAT only) if the parameter list is truncated as
+ -- a result of a First_Optional_Parameter specification in an
+ -- Import_Function, Import_Procedure, or Import_Valued_Procedure pragma.
+ -- The truncation is done by the expander by removing trailing parameters
+ -- from the argument list, in accordance with the set of rules allowing
+ -- such parameter removal. In particular, parameters can be removed
+ -- working from the end of the parameter list backwards up to and
+ -- including the entry designated by First_Optional_Parameter in the
+ -- Import pragma. Parameters can be removed if they are implicit and the
+ -- default value is a known-at-compile-time value, including the use of
+ -- the Null_Parameter attribute, or if explicit parameter values are
+ -- present that match the corresponding defaults.
-- Parent_Spec (Node4-Sem)
-- For a library unit that is a child unit spec (package or subprogram
@@ -1387,67 +1374,67 @@ package Sinfo is
-- Present_Expr (Uint3-Sem)
-- Present in an N_Variant node. This has a meaningful value only after
- -- Gigi has back annotated the tree with representation information.
- -- At this point, it contains a reference to a gcc expression that
- -- depends on the values of one or more discriminants. Give a set of
- -- discriminant values, this expression evaluates to False (zero) if
- -- variant is not present, and True (non-zero) if it is present. See
- -- unit Repinfo for further details on gigi back annotation. This
- -- field is used during ASIS processing (data decomposition annex)
- -- to determine if a field is present or not.
+ -- Gigi has back annotated the tree with representation information. At
+ -- this point, it contains a reference to a gcc expression that depends
+ -- on the values of one or more discriminants. Give a set of discriminant
+ -- values, this expression evaluates to False (zero) if variant is not
+ -- present, and True (non-zero) if it is present. See unit Repinfo for
+ -- further details on gigi back annotation. This field is used during
+ -- ASIS processing (data decomposition annex) to determine if a field is
+ -- present or not.
-- Print_In_Hex (Flag13-Sem)
- -- Set on an N_Integer_Literal node to indicate that the value should
- -- be printed in hexadecimal in the sprint listing. Has no effect on
- -- legality or semantics of program, only on the displayed output.
- -- This is used to clarify output from the packed array cases.
+ -- Set on an N_Integer_Literal node to indicate that the value should be
+ -- printed in hexadecimal in the sprint listing. Has no effect on
+ -- legality or semantics of program, only on the displayed output. This
+ -- is used to clarify output from the packed array cases.
-- Procedure_To_Call (Node4-Sem)
-- Present in N_Allocator, N_Free_Statement, and N_Return_Statement
- -- nodes. References the entity for the declaration of the procedure
- -- to be called to accomplish the required operation (i.e. for the
- -- Allocate procedure in the case of N_Allocator and N_Return_Statement
- -- (for allocating the return value), and for the Deallocate procedure
- -- in the case of N_Free_Statement.
+ -- nodes. References the entity for the declaration of the procedure to
+ -- be called to accomplish the required operation (i.e. for the Allocate
+ -- procedure in the case of N_Allocator and N_Return_Statement (for
+ -- allocating the return value), and for the Deallocate procedure in the
+ -- case of N_Free_Statement.
-- Raises_Constraint_Error (Flag7-Sem)
- -- Set on an expression whose evaluation will definitely fail a
- -- constraint error check. In the case of static expressions, this
- -- flag must be set accurately (and if it is set, the expression is
- -- typically illegal unless it appears as a non-elaborated branch of
- -- a short-circuit form). For a non-static expression, this flag may
- -- be set whenever an expression (e.g. an aggregate) is known to raise
- -- constraint error. If set, the expression definitely will raise CE
- -- if elaborated at runtime. If not set, the expression may or may
- -- not raise CE. In other words, on static expressions, the flag is
- -- set accurately, on non-static expressions it is set conservatively.
+ -- Set on an expression whose evaluation will definitely fail constraint
+ -- error check. In the case of static expressions, this flag must be set
+ -- accurately (and if it is set, the expression is typically illegal
+ -- unless it appears as a non-elaborated branch of a short-circuit form).
+ -- For a non-static expression, this flag may be set whenever an
+ -- expression (e.g. an aggregate) is known to raise constraint error. If
+ -- set, the expression definitely will raise CE if elaborated at runtime.
+ -- If not set, the expression may or may not raise CE. In other words, on
+ -- static expressions, the flag is set accurately, on non-static
+ -- expressions it is set conservatively.
-- Redundant_Use (Flag13-Sem)
- -- A flag present in nodes that can appear as an operand in a use
- -- clause or use type clause (identifiers, expanded names, attribute
- -- references). Set to indicate that a use is redundant (and therefore
- -- need not be undone on scope exit).
+ -- Present in nodes that can appear as an operand in a use clause or use
+ -- type clause (identifiers, expanded names, attribute references). Set
+ -- to indicate that a use is redundant (and therefore need not be undone
+ -- on scope exit).
-- Return_Type (Node2-Sem)
- -- Present in N_Return_Statement node. For a procedure, this is set
- -- to Standard_Void_Type. For a function it references the entity
- -- for the returned type.
+ -- Present in N_Return_Statement node. For a procedure, this is set to
+ -- Standard_Void_Type. For a function it references the entity for the
+ -- returned type.
-- Rounded_Result (Flag18-Sem)
-- Present in N_Type_Conversion, N_Op_Divide and N_Op_Multiply nodes.
-- Used in the fixed-point cases to indicate that the result must be
- -- rounded as a result of the use of the 'Round attribute. Also used
- -- for integer N_Op_Divide nodes to indicate that the result should
- -- be rounded to the nearest integer (breaking ties away from zero),
- -- rather than truncated towards zero as usual. These rounded integer
- -- operations are the result of expansion of rounded fixed-point
- -- divide, conversion and multiplication operations.
+ -- rounded as a result of the use of the 'Round attribute. Also used for
+ -- integer N_Op_Divide nodes to indicate that the result should be
+ -- rounded to the nearest integer (breaking ties away from zero), rather
+ -- than truncated towards zero as usual. These rounded integer operations
+ -- are the result of expansion of rounded fixed-point divide, conversion
+ -- and multiplication operations.
-- Scope (Node3-Sem)
-- Present in defining identifiers, defining character literals and
- -- defining operator symbols (i.e. in all entities). The entities of
- -- a scope all use this field to reference the corresponding scope
- -- entity. See Einfo for further details.
+ -- defining operator symbols (i.e. in all entities). The entities of a
+ -- scope all use this field to reference the corresponding scope entity.
+ -- See Einfo for further details.
-- Shift_Count_OK (Flag4-Sem)
-- A flag present in shift nodes to indicate that the shift count is
@@ -1464,29 +1451,29 @@ package Sinfo is
-- Static_Processing_OK (Flag4-Sem)
-- Present in N_Aggregate nodes. When the Compile_Time_Known_Aggregate
-- flag is set, the full value of the aggregate can be determined at
- -- compile time and the aggregate can be passed as is to the back-end.
- -- In this event it is irrelevant whether this flag is set or not.
- -- However, if the Compile_Time_Known_Aggregate flag is not set but
+ -- compile time and the aggregate can be passed as is to the back-end. In
+ -- this event it is irrelevant whether this flag is set or not. However,
+ -- if the Compile_Time_Known_Aggregate flag is not set but
-- Static_Processing_OK is set, the aggregate can (but need not) be
- -- converted into a compile time known aggregate by the expander.
- -- See Sem_Aggr for the specific conditions under which an aggregate
- -- has its Static_Processing_OK flag set.
+ -- converted into a compile time known aggregate by the expander. See
+ -- Sem_Aggr for the specific conditions under which an aggregate has its
+ -- Static_Processing_OK flag set.
-- Storage_Pool (Node1-Sem)
- -- Present in N_Allocator, N_Free_Statement and N_Return_Statement
- -- nodes. References the entity for the storage pool to be used for
- -- the allocate or free call or for the allocation of the returned
- -- value from a function. Empty indicates that the global default
- -- default pool is to be used. Note that in the case of a return
- -- statement, this field is set only if the function returns a
- -- value of a type whose size is not known at compile time on the
- -- secondary stack. It is never set on targets for which the target
- -- parameter Targparm.Functions_Return_By_DSP_On_Target is True.
+ -- Present in N_Allocator, N_Free_Statement and N_Return_Statement nodes.
+ -- References the entity for the storage pool to be used for the allocate
+ -- or free call or for the allocation of the returned value from a
+ -- function. Empty indicates that the global default default pool is to
+ -- be used. Note that in the case of a return statement, this field is
+ -- set only if the function returns value of a type whose size is not
+ -- known at compile time on the secondary stack. It is never set on
+ -- targets for which the parameter Functions_Return_By_DSP_On_Target in
+ -- Targparm is True.
-- Target_Type (Node2-Sem)
- -- Used in an N_Validate_Unchecked_Conversion node to point to the
- -- target type entity for the unchecked conversion instantiation
- -- which gigi must do size validation for.
+ -- Used in an N_Validate_Unchecked_Conversion node to point to the target
+ -- type entity for the unchecked conversion instantiation which gigi must
+ -- do size validation for.
-- Then_Actions (List3-Sem)
-- This field is present in conditional expression nodes. During code
@@ -1494,55 +1481,55 @@ package Sinfo is
-- actions at an appropriate place in the tree to get elaborated at the
-- right time. For conditional expressions, we have to be sure that the
-- actions for the Then branch are only elaborated if the condition is
- -- True. The Then_Actions field is used as a temporary parking place
- -- for these actions. The final tree is always rewritten to eliminate
- -- the need for this field, so in the tree passed to Gigi, this field
- -- is always set to No_List.
+ -- True. The Then_Actions field is used as a temporary parking place for
+ -- these actions. The final tree is always rewritten to eliminate the
+ -- need for this field, so in the tree passed to Gigi, this field is
+ -- always set to No_List.
-- Treat_Fixed_As_Integer (Flag14-Sem)
- -- This flag appears in operator nodes for divide, multiply, mod and
- -- rem on fixed-point operands. It indicates that the operands are
- -- to be treated as integer values, ignoring small values. This flag
- -- is only set as a result of expansion of fixed-point operations.
- -- Typically a fixed-point multplication in the source generates
- -- subsidiary multiplication and division operations that work with
- -- the underlying integer values and have this flag set. Note that
- -- this flag is not needed on other arithmetic operations (add, neg,
- -- subtract etc) since in these cases it is always the case that fixed
- -- is treated as integer. The Etype field MUST be set if this flag
- -- is set. The analyzer knows to leave such nodes alone, and whoever
- -- makes them must set the correct Etype value.
+ -- This flag appears in operator nodes for divide, multiply, mod and rem
+ -- on fixed-point operands. It indicates that the operands are to be
+ -- treated as integer values, ignoring small values. This flag is only
+ -- set as a result of expansion of fixed-point operations. Typically a
+ -- fixed-point multplication in the source generates subsidiary
+ -- multiplication and division operations that work with the underlying
+ -- integer values and have this flag set. Note that this flag is not
+ -- needed on other arithmetic operations (add, neg, subtract etc) since
+ -- in these cases it is always the case that fixed is treated as integer.
+ -- The Etype field MUST be set if this flag is set. The analyzer knows to
+ -- leave such nodes alone, and whoever makes them must set the correct
+ -- Etype value.
-- TSS_Elist (Elist3-Sem)
-- Present in N_Freeze_Entity nodes. Holds an element list containing
-- entries for each TSS (type support subprogram) associated with the
-- frozen type. The elements of the list are the entities for the
- -- subprograms (see package Exp_TSS for further details). Set to
- -- No_Elist if there are no type support subprograms for the type
- -- or if the freeze node is not for a type.
+ -- subprograms (see package Exp_TSS for further details). Set to No_Elist
+ -- if there are no type support subprograms for the type or if the freeze
+ -- node is not for a type.
-- Unreferenced_In_Spec (Flag7-Sem)
-- Present in N_With_Clause nodes. Set if the with clause is on the
-- package or subprogram spec where the main unit is the corresponding
- -- body, and is not referenced by the spec (it may still be referenced
- -- by the body, so this flag is used to generate the proper message
- -- (see Sem_Util.Check_Unused_Withs for details)
+ -- body, and is not referenced by the spec (it may still be referenced by
+ -- the body, so this flag is used to generate the proper message (see
+ -- Sem_Util.Check_Unused_Withs for details)
-- Was_Originally_Stub (Flag13-Sem)
- -- This flag is set in the node for a proper body that replaces a
- -- stub. During the analysis procedure, stubs in some situations
- -- get rewritten by the corresponding bodies, and we set this flag
- -- to remember that this happened. Note that it is not good enough
- -- to rely on the use of Original_Node here because of the case of
- -- nested instantiations where the substituted node can be copied.
+ -- This flag is set in the node for a proper body that replaces stub.
+ -- During the analysis procedure, stubs in some situations get rewritten
+ -- by the corresponding bodies, and we set this flag to remember that
+ -- this happened. Note that it is not good enough to rely on the use of
+ -- Original_Node here because of the case of nested instantiations where
+ -- the substituted node can be copied.
-- Zero_Cost_Handling (Flag5-Sem)
-- This flag is set in all handled sequence of statement and exception
-- handler nodes if eceptions are to be handled using the zero-cost
-- mechanism (see Ada.Exceptions and System.Exceptions in files
- -- a-except.ads/adb and s-except.ads for full details). What gigi
- -- needs to do for such a handler is simply to put the code in the
- -- handler somewhere. The front end has generated all necessary labels.
+ -- a-except.ads/adb and s-except.ads for full details). What gigi needs
+ -- to do for such a handler is simply to put the code in the handler
+ -- somewhere. The front end has generated all necessary labels.
--------------------------------------------------
-- Note on Use of End_Label and End_Span Fields --
@@ -1569,46 +1556,43 @@ package Sinfo is
-- Record Definition end record;
-- Enumeration Definition );
- -- The End_Label and End_Span fields are used to mark the locations
- -- of these lines, and also keep track of the label in the case where
- -- a label is present.
-
- -- For the first group above, the End_Label field of the corresponding
- -- node is used to point to the label identifier. In the case where
- -- there is no label in the source, the parser supplies a dummy
- -- identifier (with Comes_From_Source set to False), and the Sloc
- -- of this dummy identifier marks the location of the token following
- -- the END token.
-
- -- For the second group, the use of End_Label is similar, but the
- -- End_Label is found in the N_Handled_Sequence_Of_Statements node.
- -- This is done simply because in some cases there is no room in
- -- the parent node.
-
- -- For the third group, there is never any label, and instead of
- -- using End_Label, we use the End_Span field which gives the
- -- location of the token following END, relative to the starting
- -- Sloc of the construct, i.e. add Sloc (Node) + End_Span (Node)
- -- to get the Sloc of the IF or CASE following the End_Label.
-
- -- The record definition case is handled specially, we treat it
- -- as though it required an optional label which is never present,
- -- and so the parser always builds a dummy identifier with Comes
- -- From Source set False. The reason we do this, rather than using
- -- End_Span in this case, is that we want to generate a cross-ref
- -- entry for the end of a record, since it represents a scope for
- -- name declaration purposes.
-
- -- The enumeration definition case is handled in an exactly similar
- -- manner, building a dummy identifier to get a cross-reference.
-
- -- Note: the reason we store the difference as a Uint, instead of
- -- storing the Source_Ptr value directly, is that Source_Ptr values
- -- cannot be distinguished from other types of values, and we count
- -- on all general use fields being self describing. To make things
- -- easier for clients, note that we provide function End_Location,
- -- and procedure Set_End_Location to allow access to the logical
- -- value (which is the Source_Ptr value for the end token).
+ -- The End_Label and End_Span fields are used to mark the locations of
+ -- these lines, and also keep track of the label in the case where a label
+ -- is present.
+
+ -- For the first group above, the End_Label field of the corresponding node
+ -- is used to point to the label identifier. In the case where there is no
+ -- label in the source, the parser supplies a dummy identifier (with
+ -- Comes_From_Source set to False), and the Sloc of this dummy identifier
+ -- marks the location of the token following the END token.
+
+ -- For the second group, the use of End_Label is similar, but the End_Label
+ -- is found in the N_Handled_Sequence_Of_Statements node. This is done
+ -- simply because in some cases there is no room in the parent node.
+
+ -- For the third group, there is never any label, and instead of using
+ -- End_Label, we use the End_Span field which gives the location of the
+ -- token following END, relative to the starting Sloc of the construct,
+ -- i.e. add Sloc (Node) + End_Span (Node) to get the Sloc of the IF or CASE
+ -- following the End_Label.
+
+ -- The record definition case is handled specially, we treat it as though
+ -- it required an optional label which is never present, and so the parser
+ -- always builds a dummy identifier with Comes From Source set False. The
+ -- reason we do this, rather than using End_Span in this case, is that we
+ -- want to generate a cross-ref entry for the end of a record, since it
+ -- represents a scope for name declaration purposes.
+
+ -- The enumeration definition case is handled in an exactly similar manner,
+ -- building a dummy identifier to get a cross-reference.
+
+ -- Note: the reason we store the difference as a Uint, instead of storing
+ -- the Source_Ptr value directly, is that Source_Ptr values cannot be
+ -- distinguished from other types of values, and we count on all general
+ -- use fields being self describing. To make things easier for clients,
+ -- note that we provide function End_Location, and procedure
+ -- Set_End_Location to allow access to the logical value (which is the
+ -- Source_Ptr value for the end token).
---------------------
-- Syntactic Nodes --
@@ -1623,23 +1607,23 @@ package Sinfo is
-- An IDENTIFIER shall not be a reserved word
- -- In the Ada grammar identifiers are the bottom level tokens which
- -- have very few semantics. Actual program identifiers are direct
- -- names. If we were being 100% honest with the grammar, then we would
- -- have a node called N_Direct_Name which would point to an identifier.
- -- However, that's too many extra nodes, so we just use the N_Identifier
- -- node directly as a direct name, and it contains the expression fields
- -- and Entity field that correspond to its use as a direct name. In
- -- those few cases where identifiers appear in contexts where they are
- -- not direct names (pragmas, pragma argument associations, attribute
+ -- In the Ada grammar identifiers are the bottom level tokens which have
+ -- very few semantics. Actual program identifiers are direct names. If
+ -- we were being 100% honest with the grammar, then we would have a node
+ -- called N_Direct_Name which would point to an identifier. However,
+ -- that's too many extra nodes, so we just use the N_Identifier node
+ -- directly as a direct name, and it contains the expression fields and
+ -- Entity field that correspond to its use as a direct name. In those
+ -- few cases where identifiers appear in contexts where they are not
+ -- direct names (pragmas, pragma argument associations, attribute
-- references and attribute definition clauses), the Chars field of the
-- node contains the Name_Id for the identifier name.
- -- Note: in GNAT, a reserved word can be treated as an identifier
- -- in two cases. First, an incorrect use of a reserved word as an
- -- identifier is diagnosed and then treated as a normal identifier.
- -- Second, an attribute designator of the form of a reserved word
- -- (access, delta, digits, range) is treated as an identifier.
+ -- Note: in GNAT, a reserved word can be treated as an identifier in two
+ -- cases. First, an incorrect use of a reserved word as an identifier is
+ -- diagnosed and then treated as a normal identifier. Second, an
+ -- attribute designator of the form of a reserved word (access, delta,
+ -- digits, range) is treated as an identifier.
-- Note: The set of letters that is permitted in an identifier depends
-- on the character set in use. See package Csets for full details.
@@ -1735,12 +1719,12 @@ package Sinfo is
-- Has_Private_View (Flag11-Sem) set in generic units.
-- plus fields for expression
- -- Note: the Entity field will be missing (and set to Empty) for
- -- character literals whose type is Standard.Wide_Character or
- -- Standard.Character or a type derived from one of these two.
- -- In this case the character literal stands for its own coding.
- -- The reason we take this irregular short cut is to avoid the
- -- need to build lots of junk defining character literal nodes.
+ -- Note: the Entity field will be missing (set to Empty) for character
+ -- literals whose type is Standard.Wide_Character or Standard.Character
+ -- or a type derived from one of these two. In this case the character
+ -- literal stands for its own coding. The reason we take this irregular
+ -- short cut is to avoid the need to build lots of junk defining
+ -- character literal nodes.
-------------------------
-- 2.6 String Literal --
@@ -5701,7 +5685,8 @@ package Sinfo is
--------------------------------------------
-- FORMAL_DERIVED_TYPE_DEFINITION ::=
- -- [abstract] new SUBTYPE_MARK [[and INTERFACE_LIST] with private]
+ -- [abstract] [limited]
+ -- new SUBTYPE_MARK [[and INTERFACE_LIST] with private]
-- Note: this construct is not allowed in Ada 83 mode
-- N_Formal_Derived_Type_Definition
@@ -5709,6 +5694,7 @@ package Sinfo is
-- Subtype_Mark (Node4)
-- Private_Present (Flag15)
-- Abstract_Present (Flag4)
+ -- Limited_Present (Flag17)
-- Interface_List (List2) (set to No_List if none)
---------------------------------------------
diff --git a/gcc/ada/sprint.adb b/gcc/ada/sprint.adb
index 58e61df8967..08e6cf892a6 100644
--- a/gcc/ada/sprint.adb
+++ b/gcc/ada/sprint.adb
@@ -193,7 +193,7 @@ package body Sprint is
-- declarations that can have discriminants.
procedure Write_Ekind (E : Entity_Id);
- -- Write the String corresponding to the Ekind without "E_".
+ -- Write the String corresponding to the Ekind without "E_"
procedure Write_Id (N : Node_Id);
-- N is a node with a Chars field. This procedure writes the name that
@@ -203,7 +203,8 @@ package body Sprint is
-- the name associated with the entity (since it may have been encoded).
-- One other special case is that an entity has an active external name
-- (i.e. an external name present with no address clause), then this
- -- external name is output.
+ -- external name is output. This procedure also deals with outputting
+ -- declarations of referenced itypes, if not output earlier.
function Write_Identifiers (Node : Node_Id) return Boolean;
-- Handle node where the grammar has a list of defining identifiers, but
@@ -238,6 +239,10 @@ package body Sprint is
-- the Sloc of the current node is set to the first non-blank character
-- in the string S.
+ procedure Write_Itype (Typ : Entity_Id);
+ -- If Typ is an Itype that has not been written yet, write it. If Typ is
+ -- any other kind of entity or tree node, the call is ignored.
+
procedure Write_Name_With_Col_Check (N : Name_Id);
-- Write name (using Write_Name) with initial column check, and possible
-- initial Write_Indent (to get new line) if current line is too full.
@@ -272,6 +277,11 @@ package body Sprint is
-- Like Write_Str_WIth_Col_Check, but sets debug Sloc of current debug
-- node to first non-blank character if a current debug node is active.
+ procedure Write_Uint_With_Col_Check (U : Uint; Format : UI_Format);
+ -- Write Uint (using UI_Write) with initial column check, and possible
+ -- initial Write_Indent (to get new line) if current line is too full.
+ -- The format parameter determines the output format (see UI_Write).
+
procedure Write_Uint_With_Col_Check_Sloc (U : Uint; Format : UI_Format);
-- Write Uint (using UI_Write) with initial column check, and possible
-- initial Write_Indent (to get new line) if current line is too full.
@@ -417,7 +427,7 @@ package body Sprint is
Write_Eol;
end Underline;
- -- Start of processing for Tree_Dump.
+ -- Start of processing for Tree_Dump
begin
Dump_Generated_Only := Debug_Flag_G or
@@ -1078,7 +1088,6 @@ package body Sprint is
Condition : constant Node_Id := First (Expressions (Node));
Then_Expr : constant Node_Id := Next (Condition);
Else_Expr : constant Node_Id := Next (Then_Expr);
-
begin
Write_Str_With_Col_Check_Sloc ("(if ");
Sprint_Node (Condition);
@@ -2344,7 +2353,6 @@ package body Sprint is
declare
Alt_Node : Node_Id;
-
begin
Alt_Node := First (Select_Alternatives (Node));
loop
@@ -2607,7 +2615,6 @@ package body Sprint is
declare
Node1 : Node_Id;
-
begin
Node1 := First (Subtype_Marks (Node));
loop
@@ -2808,9 +2815,7 @@ package body Sprint is
if Dump_Original_Only then
N := First (List);
-
while Present (N) loop
-
if not Is_Rewrite_Insertion (N) then
Node_Exists := True;
exit;
@@ -2944,6 +2949,19 @@ package body Sprint is
procedure Write_Id (N : Node_Id) is
begin
+ -- Deal with outputting Itype
+
+ -- Note: if we are printing the full tree with -gnatds, then we may
+ -- end up picking up the Associated_Node link from a generic template
+ -- here which overlaps the Entity field, but as documented, Write_Itype
+ -- is defended against junk calls.
+
+ if Nkind (N) in N_Entity then
+ Write_Itype (N);
+ elsif Nkind (N) in N_Has_Entity then
+ Write_Itype (Entity (N));
+ end if;
+
-- Case of a defining identifier
if Nkind (N) = N_Defining_Identifier then
@@ -3022,7 +3040,6 @@ package body Sprint is
Write_Str_With_Col_Check (" (");
Ind := First_Index (E);
-
while Present (Ind) loop
Sprint_Node (Ind);
Next_Index (Ind);
@@ -3153,6 +3170,266 @@ package body Sprint is
Write_Str_Sloc (S);
end Write_Indent_Str_Sloc;
+ -----------------
+ -- Write_Itype --
+ -----------------
+
+ procedure Write_Itype (Typ : Entity_Id) is
+
+ procedure Write_Header (T : Boolean := True);
+ -- Write type if T is True, subtype if T is false
+
+ ------------------
+ -- Write_Header --
+ ------------------
+
+ procedure Write_Header (T : Boolean := True) is
+ begin
+ if T then
+ Write_Str ("[type ");
+ else
+ Write_Str ("[subtype ");
+ end if;
+
+ Write_Name_With_Col_Check (Chars (Typ));
+ Write_Str (" is ");
+ end Write_Header;
+
+ -- Start of processing for Write_Itype
+
+ begin
+ if Nkind (Typ) in N_Entity
+ and then Is_Itype (Typ)
+ and then not Itype_Printed (Typ)
+ then
+ -- Itype to be printed
+
+ declare
+ B : constant Node_Id := Etype (Typ);
+ X : Node_Id;
+ P : constant Node_Id := Parent (Typ);
+
+ S : constant Saved_Output_Buffer := Save_Output_Buffer;
+ -- Save current output buffer
+
+ begin
+ -- Write indentation at start of line
+
+ for J in 1 .. Indent loop
+ Write_Char (' ');
+ end loop;
+
+ -- If we have a constructed declaration, print it
+
+ if Present (P) and then Nkind (P) in N_Declaration then
+
+ -- We must set Itype_Printed true before the recursive call to
+ -- print the node, otherwise we get an infinite recursion!
+
+ Set_Itype_Printed (Typ, True);
+
+ -- Write the declaration enclosed in [], avoiding new line
+ -- at start of declaration, and semicolon at end.
+
+ Write_Char ('[');
+ Indent_Annull_Flag := True;
+ Sprint_Node (P);
+ Write_Erase_Char (';');
+
+ -- If no constructed declaration, then we have to concoct the
+ -- source corresponding to the type entity that we have at hand.
+
+ else
+ case Ekind (Typ) is
+
+ -- Access types and subtypes
+
+ when Access_Kind =>
+ Write_Header (Ekind (Typ) = E_Access_Type);
+ Write_Str ("access ");
+
+ if Is_Access_Constant (Typ) then
+ Write_Str ("constant ");
+ elsif Can_Never_Be_Null (Typ) then
+ Write_Str ("not null ");
+ end if;
+
+ Write_Id (Directly_Designated_Type (Typ));
+
+ -- Array types and string types
+
+ when E_Array_Type | E_String_Type =>
+ Write_Header;
+ Write_Str ("array (");
+
+ X := First_Index (Typ);
+ loop
+ Sprint_Node (X);
+
+ if not Is_Constrained (Typ) then
+ Write_Str (" range <>");
+ end if;
+
+ Next_Index (X);
+ exit when No (X);
+ Write_Str (", ");
+ end loop;
+
+ Write_Str (") of ");
+ Sprint_Node (Component_Type (Typ));
+
+ -- Array subtypes and string subtypes
+
+ when E_Array_Subtype | E_String_Subtype =>
+ Write_Header (False);
+ Write_Id (Etype (Typ));
+ Write_Str (" (");
+
+ X := First_Index (Typ);
+ loop
+ Sprint_Node (X);
+ Next_Index (X);
+ exit when No (X);
+ Write_Str (", ");
+ end loop;
+
+ Write_Char (')');
+
+ -- Signed integer types, and modular integer subtypes
+
+ when E_Signed_Integer_Type |
+ E_Signed_Integer_Subtype |
+ E_Modular_Integer_Subtype =>
+
+ Write_Header (Ekind (Typ) = E_Signed_Integer_Type);
+
+ if Ekind (Typ) = E_Signed_Integer_Type then
+ Write_Str ("new ");
+ end if;
+
+ Write_Id (B);
+
+ -- Print bounds if not different from base type
+
+ declare
+ L : constant Node_Id := Type_Low_Bound (Typ);
+ H : constant Node_Id := Type_High_Bound (Typ);
+ LE : constant Node_Id := Type_Low_Bound (B);
+ HE : constant Node_Id := Type_High_Bound (B);
+
+ begin
+ if Nkind (L) = N_Integer_Literal
+ and then Nkind (H) = N_Integer_Literal
+ and then Nkind (LE) = N_Integer_Literal
+ and then Nkind (HE) = N_Integer_Literal
+ and then UI_Eq (Intval (L), Intval (LE))
+ and then UI_Eq (Intval (H), Intval (HE))
+ then
+ null;
+
+ else
+ Write_Str (" range ");
+ Sprint_Node (Type_Low_Bound (Typ));
+ Write_Str (" .. ");
+ Sprint_Node (Type_High_Bound (Typ));
+ end if;
+ end;
+
+ -- Modular integer types
+
+ when E_Modular_Integer_Type =>
+ Write_Header;
+ Write_Str (" mod ");
+ Write_Uint_With_Col_Check (Modulus (Typ), Auto);
+
+ -- Floating point types and subtypes
+
+ when E_Floating_Point_Type |
+ E_Floating_Point_Subtype =>
+
+ Write_Header (Ekind (Typ) = E_Floating_Point_Type);
+
+ if Ekind (Typ) = E_Floating_Point_Type then
+ Write_Str ("new ");
+ end if;
+
+ Write_Id (Etype (Typ));
+
+ if Digits_Value (Typ) /= Digits_Value (Etype (Typ)) then
+ Write_Str (" digits ");
+ Write_Uint_With_Col_Check
+ (Digits_Value (Typ), Decimal);
+ end if;
+
+ -- Print bounds if not different from base type
+
+ declare
+ L : constant Node_Id := Type_Low_Bound (Typ);
+ H : constant Node_Id := Type_High_Bound (Typ);
+ LE : constant Node_Id := Type_Low_Bound (B);
+ HE : constant Node_Id := Type_High_Bound (B);
+
+ begin
+ if Nkind (L) = N_Real_Literal
+ and then Nkind (H) = N_Real_Literal
+ and then Nkind (LE) = N_Real_Literal
+ and then Nkind (HE) = N_Real_Literal
+ and then UR_Eq (Realval (L), Realval (LE))
+ and then UR_Eq (Realval (H), Realval (HE))
+ then
+ null;
+
+ else
+ Write_Str (" range ");
+ Sprint_Node (Type_Low_Bound (Typ));
+ Write_Str (" .. ");
+ Sprint_Node (Type_High_Bound (Typ));
+ end if;
+ end;
+
+ -- Record subtypes
+
+ when E_Record_Subtype =>
+ Write_Header (False);
+ Write_Str ("record");
+ Indent_Begin;
+
+ declare
+ C : Entity_Id;
+ begin
+ C := First_Entity (Typ);
+ while Present (C) loop
+ Write_Indent;
+ Write_Id (C);
+ Write_Str (" : ");
+ Write_Id (Etype (C));
+ Next_Entity (C);
+ end loop;
+ end;
+
+ Indent_End;
+ Write_Indent_Str (" end record");
+
+ -- For all other Itypes, print ??? (fill in later)
+
+ when others =>
+ Write_Header (True);
+ Write_Str ("???");
+
+ end case;
+ end if;
+
+ -- Add terminating bracket and restore output buffer
+
+ Write_Char (']');
+ Write_Eol;
+ Restore_Output_Buffer (S);
+ end;
+
+ Set_Itype_Printed (Typ);
+ end if;
+ end Write_Itype;
+
-------------------------------
-- Write_Name_With_Col_Check --
-------------------------------
@@ -3167,7 +3444,6 @@ package body Sprint is
-- name by three dots (e.g. R7b becomes R...b).
if Debug_Flag_II and then Name_Buffer (1) in 'A' .. 'Z' then
-
J := 2;
while J < Name_Len loop
exit when Name_Buffer (J) not in 'A' .. 'Z';
@@ -3355,6 +3631,16 @@ package body Sprint is
end if;
end Write_Str_With_Col_Check_Sloc;
+ -------------------------------
+ -- Write_Uint_With_Col_Check --
+ -------------------------------
+
+ procedure Write_Uint_With_Col_Check (U : Uint; Format : UI_Format) is
+ begin
+ Col_Check (UI_Decimal_Digits_Hi (U));
+ UI_Write (U, Format);
+ end Write_Uint_With_Col_Check;
+
------------------------------------
-- Write_Uint_With_Col_Check_Sloc --
------------------------------------
diff --git a/gcc/ada/sprint.ads b/gcc/ada/sprint.ads
index d10a009ea47..997e7a4bd22 100644
--- a/gcc/ada/sprint.ads
+++ b/gcc/ada/sprint.ads
@@ -58,6 +58,7 @@ package Sprint is
-- Freeze entity with freeze actions freeze entityname [ actions ]
-- Interpretation interpretation type [, entity]
-- Intrinsic calls function-name!(arg, arg, arg)
+ -- Itype declaration [(sub)type declaration without ;]
-- Itype reference reference itype
-- Label declaration labelname : label
-- Mod wi Treat_Fixed_As_Integer x #mod y