From 5a15af6295629fe3ad95a3d93aa7ffca7fc65a00 Mon Sep 17 00:00:00 2001 From: Ed Schonberg Date: Fri, 26 Oct 2001 01:26:05 +0000 Subject: sem_util.adb (Defining_Entity): in case of error... * sem_util.adb (Defining_Entity): in case of error, attach created entity to specification, so that semantic analysis can proceed. From-SVN: r46515 --- gcc/ada/ChangeLog | 5 +++++ gcc/ada/sem_util.adb | 10 +++++++--- 2 files changed, 12 insertions(+), 3 deletions(-) (limited to 'gcc') diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog index 2088cec..ecb970a 100644 --- a/gcc/ada/ChangeLog +++ b/gcc/ada/ChangeLog @@ -1,3 +1,8 @@ +2001-10-25 Ed Schonberg + + * sem_util.adb (Defining_Entity): in case of error, attach created + entity to specification, so that semantic analysis can proceed. + 2001-10-25 Robert Dewar * sem_util.adb diff --git a/gcc/ada/sem_util.adb b/gcc/ada/sem_util.adb index 658bef6..7bc2b92 100644 --- a/gcc/ada/sem_util.adb +++ b/gcc/ada/sem_util.adb @@ -1103,7 +1103,8 @@ package body Sem_Util is --------------------- function Defining_Entity (N : Node_Id) return Entity_Id is - K : constant Node_Kind := Nkind (N); + K : constant Node_Kind := Nkind (N); + Err : Entity_Id := Empty; begin case K is @@ -1178,13 +1179,16 @@ package body Sem_Util is if Nkind (Nam) in N_Entity then return Nam; - -- For Error, make up a name so we can continue + -- For Error, make up a name and attach to declaration + -- so we can continue semantic analysis elsif Nam = Error then - return + Err := Make_Defining_Identifier (Sloc (N), Chars => New_Internal_Name ('T')); + Set_Defining_Unit_Name (N, Err); + return Err; -- If not an entity, get defining identifier else -- cgit v1.1