diff options
Diffstat (limited to 'gcc/ada')
-rw-r--r-- | gcc/ada/ChangeLog | 11 | ||||
-rw-r--r-- | gcc/ada/freeze.adb | 15 | ||||
-rw-r--r-- | gcc/ada/gnat_rm.texi | 19 | ||||
-rw-r--r-- | gcc/ada/opt.ads | 6 | ||||
-rw-r--r-- | gcc/ada/sem_prag.adb | 15 |
5 files changed, 38 insertions, 28 deletions
diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog index 01d84ba..2c1f914 100644 --- a/gcc/ada/ChangeLog +++ b/gcc/ada/ChangeLog @@ -1,5 +1,16 @@ 2013-07-05 Robert Dewar <dewar@adacore.com> + * freeze.adb (Freeze_Entity): Remove test of obsolete flag + Propagate_Exceptions, and associated useless code that did + nothing. + * gnat_rm.texi: Add documentation for obsolete pragma + Propagate_Exceptions. + * opt.ads (Propagate_Exceptions): Obsolete flag removed. + * sem_prag.adb (Analyze_Pragma, case Propagate_Exceptions): + Remove useless and obsolete setting of Propagate_Exceptions flag. + +2013-07-05 Robert Dewar <dewar@adacore.com> + * gnat_rm.texi, sem_prag.adb: Minor comment/text fixes. 2013-07-05 Robert Dewar <dewar@adacore.com> diff --git a/gcc/ada/freeze.adb b/gcc/ada/freeze.adb index 88a8f6d..125c3bc 100644 --- a/gcc/ada/freeze.adb +++ b/gcc/ada/freeze.adb @@ -4940,21 +4940,6 @@ package body Freeze is and then not Is_Library_Level_Entity (E) then Set_Is_Public (E, False); - - -- If no address clause and not intrinsic, then for imported - -- subprogram in main unit, generate descriptor if we are in - -- Propagate_Exceptions mode. - - -- This is very odd code, it makes a null result, why ??? - - elsif Propagate_Exceptions - and then Is_Imported (E) - and then not Is_Intrinsic_Subprogram (E) - and then Convention (E) /= Convention_Stubbed - then - if Result = No_List then - Result := Empty_List; - end if; end if; end if; diff --git a/gcc/ada/gnat_rm.texi b/gcc/ada/gnat_rm.texi index 312e0a8..cb559a3 100644 --- a/gcc/ada/gnat_rm.texi +++ b/gcc/ada/gnat_rm.texi @@ -206,6 +206,7 @@ Implementation Defined Pragmas * Pragma Priority_Specific_Dispatching:: * Pragma Profile:: * Pragma Profile_Warnings:: +* Pragma Propagate_Exceptions:: * Pragma Psect_Object:: * Pragma Pure_05:: * Pragma Pure_12:: @@ -1010,6 +1011,7 @@ consideration, the use of these pragmas should be minimized. * Pragma Priority_Specific_Dispatching:: * Pragma Profile:: * Pragma Profile_Warnings:: +* Pragma Propagate_Exceptions:: * Pragma Psect_Object:: * Pragma Pure_05:: * Pragma Pure_12:: @@ -5288,7 +5290,24 @@ generating @code{Restrictions} pragmas, it generates violations of the profile generate warning messages instead of error messages. +@node Pragma Propagate_Exceptions +@unnumberedsec Pragma Propagate_Exceptions +@cindex Interfacing to C++ +@findex Propagate_Exceptions +@noindent +Syntax: + +@smallexample @c ada +pragma Propagate_Exceptions; +@end smallexample + @noindent +This pragma is now obsolete and, other than generating a warning if warnings +on obsolescent features are enabled, is ignored. +It is retained for compatibility +purposes. It used to be used in connection with optimization of +a now-obsolete mechanism for implementation of exceptions. + @node Pragma Psect_Object @unnumberedsec Pragma Psect_Object @findex Psect_Object diff --git a/gcc/ada/opt.ads b/gcc/ada/opt.ads index 01cbad1..54d39f8 100644 --- a/gcc/ada/opt.ads +++ b/gcc/ada/opt.ads @@ -1147,12 +1147,6 @@ package Opt is -- Set to true to enable printing of package standard in source form. -- This flag is set by the -gnatS switch - Propagate_Exceptions : Boolean := False; - -- GNAT - -- Indicates if subprogram descriptor exception tables should be - -- built for imported subprograms. Set True if a Propagate_Exceptions - -- pragma applies to the extended main unit. - type Usage is (Unknown, Not_In_Use, In_Use); Project_File_In_Use : Usage := Unknown; -- GNAT diff --git a/gcc/ada/sem_prag.adb b/gcc/ada/sem_prag.adb index 553ce21..3f70c8f 100644 --- a/gcc/ada/sem_prag.adb +++ b/gcc/ada/sem_prag.adb @@ -10300,7 +10300,7 @@ package body Sem_Prag is if Warn_On_Obsolescent_Feature then Error_Msg_N - ("'G'N'A'T pragma cpp'_virtual is now obsolete and has no " + ("'G'N'A'T pragma Cpp'_Virtual is now obsolete and has no " & "effect?j?", N); end if; end CPP_Virtual; @@ -10315,7 +10315,7 @@ package body Sem_Prag is if Warn_On_Obsolescent_Feature then Error_Msg_N - ("'G'N'A'T pragma cpp'_vtable is now obsolete and has no " + ("'G'N'A'T pragma Cpp'_Vtable is now obsolete and has no " & "effect?j?", N); end if; end CPP_Vtable; @@ -14604,6 +14604,7 @@ package body Sem_Prag is when Pragma_Overriding_Renamings => GNAT_Pragma; Check_Arg_Count (0); + Check_Valid_Configuration_Pragma; Overriding_Renamings := True; ---------- @@ -15039,7 +15040,7 @@ package body Sem_Prag is -- pragma Predicate -- ([Entity =>] type_LOCAL_NAME, - -- [Check =>] EXPRESSION); + -- [Check =>] boolean_EXPRESSION); when Pragma_Predicate => Predicate : declare Type_Id : Node_Id; @@ -15469,10 +15470,10 @@ package body Sem_Prag is GNAT_Pragma; Check_Arg_Count (0); - -- This code does not agree with above (no effect) comment ??? - - if In_Extended_Main_Source_Unit (N) then - Propagate_Exceptions := True; + if Warn_On_Obsolescent_Feature then + Error_Msg_N + ("'G'N'A'T pragma Propagate'_Exceptions is now obsolete " & + "and has no effect?j?", N); end if; ------------------ |