From ce914b984f952bfe69b9425a967b0bb4490a2ac0 Mon Sep 17 00:00:00 2001 From: Vincent Celier Date: Wed, 19 Dec 2007 17:24:17 +0100 Subject: prj-attr.adb (Package_Node_Id_Of): Returns Unknown_Package when package is not known 2007-12-19 Vincent Celier * prj-attr.adb (Package_Node_Id_Of): Returns Unknown_Package when package is not known * prj-attr.ads (Unknown_Package): New constant Do not crash when an unknown package is in several projects * prj-dect.adb (Parse_Package_Declaration): Mark an unknown package as ignored * prj-nmsc.adb (Check): Remove obsolete code related to no longer existing package Language_Processing. From-SVN: r131078 --- gcc/ada/prj-dect.adb | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) (limited to 'gcc/ada/prj-dect.adb') diff --git a/gcc/ada/prj-dect.adb b/gcc/ada/prj-dect.adb index 7e367a7..24c312e 100644 --- a/gcc/ada/prj-dect.adb +++ b/gcc/ada/prj-dect.adb @@ -981,10 +981,7 @@ package body Prj.Dect is Current_Package := Package_Node_Id_Of (Token_Name); - if Current_Package /= Empty_Package then - First_Attribute := First_Attribute_Of (Current_Package); - - else + if Current_Package = Empty_Package then if not Quiet_Output then Error_Msg ("?""" & Get_Name_String @@ -1001,6 +998,16 @@ package body Prj.Dect is -- Add the unknown package in the list of packages Add_Unknown_Package (Token_Name, Current_Package); + + elsif Current_Package = Unknown_Package then + + -- Set the package declaration to "ignored" so that it is not + -- processed by Prj.Proc.Process. + + Set_Expression_Kind_Of (Package_Declaration, In_Tree, Ignored); + + else + First_Attribute := First_Attribute_Of (Current_Package); end if; Set_Package_Id_Of -- cgit v1.1