diff options
-rw-r--r-- | gcc/ada/ChangeLog | 25 | ||||
-rw-r--r-- | gcc/ada/einfo.adb | 6 | ||||
-rw-r--r-- | gcc/ada/exp_aggr.adb | 2 | ||||
-rw-r--r-- | gcc/ada/freeze.adb | 121 | ||||
-rw-r--r-- | gcc/ada/gnat_rm.texi | 5 | ||||
-rw-r--r-- | gcc/ada/par-ch4.adb | 24 | ||||
-rw-r--r-- | gcc/ada/sem_attr.adb | 5 | ||||
-rw-r--r-- | gcc/ada/sem_ch12.adb | 12 | ||||
-rw-r--r-- | gcc/ada/sem_res.adb | 2 |
9 files changed, 121 insertions, 81 deletions
diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog index d33381a4629..a09a80e12fd 100644 --- a/gcc/ada/ChangeLog +++ b/gcc/ada/ChangeLog @@ -1,3 +1,28 @@ +2014-01-21 Thomas Quinot <quinot@adacore.com> + + * gnat_rm.texi (Scalar_Storage_Order): Update documentation. + +2014-01-21 Ed Schonberg <schonberg@adacore.com> + + * sem_ch12.adb (Set_Instance_Env): In Ada 2012 mode, preserve + the value of Assertions_Enabled flag when compiling an instance of + an internal unit. This facilitates the use of pre/postconditions + in generic internal units, such as the new elementary function + libraries. + +2014-01-21 Robert Dewar <dewar@adacore.com> + + * exp_aggr.adb: Minor reformatting. + * sem_attr.adb: Minor reformatting. + * sem_res.adb: Minor comment addition. + * einfo.adb: Minor comment updates. + * freeze.adb: Minor reformatting and code reorganization. + +2014-01-21 Ed Schonberg <schonberg@adacore.com> + + * par-ch4.adb (P_If_Expression): Handle more gracefully an + elsif clause that does not have an else part. + 2014-01-21 Robert Dewar <dewar@adacore.com> * checks.adb, sem_util.ads, sem_ch4.adb: Minor reformatting. diff --git a/gcc/ada/einfo.adb b/gcc/ada/einfo.adb index 65d54bb5031..88643b8ec94 100644 --- a/gcc/ada/einfo.adb +++ b/gcc/ada/einfo.adb @@ -264,8 +264,6 @@ package body Einfo is -- sense for them to be set true for certain subsets of entity kinds. See -- the spec of Einfo for further details. - -- Note: Flag1-Flag3 are not used, for historical reasons - -- Is_Frozen Flag4 -- Has_Discriminants Flag5 -- Is_Dispatching_Operation Flag6 @@ -556,6 +554,10 @@ package body Einfo is -- SPARK_Pragma_Inherited Flag265 -- SPARK_Aux_Pragma_Inherited Flag266 + -- (unused) Flag1 + -- (unused) Flag2 + -- (unused) Flag3 + -- (unused) Flag267 -- (unused) Flag268 -- (unused) Flag269 diff --git a/gcc/ada/exp_aggr.adb b/gcc/ada/exp_aggr.adb index 61470018254..6c5104bac6a 100644 --- a/gcc/ada/exp_aggr.adb +++ b/gcc/ada/exp_aggr.adb @@ -3190,7 +3190,7 @@ package body Exp_Aggr is Insert_Action (N, Make_Raise_Constraint_Error (Loc, Condition => Cond, - Reason => CE_Discriminant_Check_Failed)); + Reason => CE_Discriminant_Check_Failed)); end if; return True; diff --git a/gcc/ada/freeze.adb b/gcc/ada/freeze.adb index 6885625c67a..310511f5275 100644 --- a/gcc/ada/freeze.adb +++ b/gcc/ada/freeze.adb @@ -233,7 +233,7 @@ package body Freeze is -- Note that it is legal for a renaming_as_body to rename an intrinsic -- subprogram, as long as the renaming occurs before the new entity - -- is frozen. See RM 8.5.4 (5). + -- is frozen (RM 8.5.4 (5)). if Nkind (Body_Decl) = N_Subprogram_Renaming_Declaration and then Is_Entity_Name (Name (Body_Decl)) @@ -1174,7 +1174,6 @@ package body Freeze is Error_Msg_N ("type of non-byte-aligned component must have same scalar " & "storage order as enclosing composite", Err_Node); - end if; end if; @@ -1257,9 +1256,7 @@ package body Freeze is -- Do not attempt to analyze case where range was in error - if No (Scalar_Range (E)) - or else Error_Posted (Scalar_Range (E)) - then + if No (Scalar_Range (E)) or else Error_Posted (Scalar_Range (E)) then return; end if; @@ -1284,7 +1281,6 @@ package body Freeze is Lo_Bound := Type_Low_Bound (Ancestor); if Compile_Time_Known_Value (Lo_Bound) then - if Expr_Rep_Value (Lo_Bound) >= 0 then Set_Is_Unsigned_Type (E, True); end if; @@ -1452,10 +1448,8 @@ package body Freeze is end if; elsif Ekind (E) in Task_Kind - and then - (Nkind (Parent (E)) = N_Task_Type_Declaration - or else - Nkind (Parent (E)) = N_Single_Task_Declaration) + and then Nkind_In (Parent (E), N_Task_Type_Declaration, + N_Single_Task_Declaration) then Push_Scope (E); Freeze_All (First_Entity (E), After); @@ -1626,10 +1620,8 @@ package body Freeze is end if; elsif Ekind (E) in Task_Kind - and then - (Nkind (Parent (E)) = N_Task_Type_Declaration - or else - Nkind (Parent (E)) = N_Single_Task_Declaration) + and then Nkind_In (Parent (E), N_Task_Type_Declaration, + N_Single_Task_Declaration) then declare Ent : Entity_Id; @@ -2075,11 +2067,12 @@ package body Freeze is -- If packing was requested or if the component size was -- set explicitly, then see if bit packing is required. This -- processing is only done for base types, since all of the - -- representation aspects involved are type-related. This is not - -- just an optimization, if we start processing the subtypes, they - -- interfere with the settings on the base type (this is because - -- Is_Packed has a slightly different meaning before and after - -- freezing). + -- representation aspects involved are type-related. + + -- This is not just an optimization, if we start processing the + -- subtypes, they interfere with the settings on the base type + -- (this is because Is_Packed has a slightly different meaning + -- before and after freezing). declare Csiz : Uint; @@ -2240,10 +2233,11 @@ package body Freeze is -- Check for Atomic_Components or Aliased with unsuitable packing -- or explicit component size clause given. - if (Has_Atomic_Components (Arr) - or else Has_Aliased_Components (Arr)) - and then (Has_Component_Size_Clause (Arr) - or else Is_Packed (Arr)) + if (Has_Atomic_Components (Arr) + or else + Has_Aliased_Components (Arr)) + and then + (Has_Component_Size_Clause (Arr) or else Is_Packed (Arr)) then Alias_Atomic_Check : declare @@ -2343,19 +2337,13 @@ package body Freeze is & "accessible by separate tasks??", Clause, Arr); if Has_Component_Size_Clause (Arr) then - Error_Msg_Sloc := - Sloc - (Get_Attribute_Definition_Clause - (FS, Attribute_Component_Size)); - Error_Msg_N - ("\because of component size clause#??", - Clause); + Error_Msg_Sloc := Sloc (Get_Attribute_Definition_Clause + (FS, Attribute_Component_Size)); + Error_Msg_N ("\because of component size clause#??", Clause); elsif Has_Pragma_Pack (Arr) then - Error_Msg_Sloc := - Sloc (Get_Rep_Pragma (FS, Name_Pack)); - Error_Msg_N - ("\because of pragma Pack#??", Clause); + Error_Msg_Sloc := Sloc (Get_Rep_Pragma (FS, Name_Pack)); + Error_Msg_N ("\because of pragma Pack#??", Clause); end if; end if; @@ -2433,8 +2421,7 @@ package body Freeze is end loop; if Elmts > Intval (High_Bound - (Scalar_Range - (Standard_Integer))) + 1 + (Scalar_Range (Standard_Integer))) + 1 then Error_Msg_N ("bit packed array type may not have " @@ -2780,7 +2767,7 @@ package body Freeze is if Is_Itype (Etype (Comp)) and then Is_Record_Type (Underlying_Type - (Scope (Etype (Comp)))) + (Scope (Etype (Comp)))) then Undelay_Type (Etype (Comp)); end if; @@ -2820,21 +2807,25 @@ package body Freeze is -- Check for error of component clause given for variable -- sized type. We have to delay this test till this point, -- since the component type has to be frozen for us to know - -- if it is variable length. We omit this test in a generic - -- context, it will be applied at instantiation time. - - -- We also omit this test in CodePeer mode, since we do not - -- have sufficient info on size and representation clauses. + -- if it is variable length. if Present (CC) then Placed_Component := True; + -- We omit this test in a generic context, it will be + -- applied at instantiation time. + if Inside_A_Generic then null; + -- Also omit this test in CodePeer mode, since we do not + -- have sufficient info on size and rep clauses. + elsif CodePeer_Mode then null; + -- Do the check + elsif not Size_Known_At_Compile_Time (Underlying_Type (Etype (Comp))) @@ -3011,11 +3002,11 @@ package body Freeze is and then Present (Expression (Parent (Comp))) and then Nkind (Expression (Parent (Comp))) = N_Aggregate and then Is_Fully_Defined - (Designated_Type (Component_Type (Etype (Comp)))) + (Designated_Type (Component_Type (Etype (Comp)))) then Freeze_And_Append (Designated_Type - (Component_Type (Etype (Comp))), N, Result); + (Component_Type (Etype (Comp))), N, Result); end if; Prev := Comp; @@ -3816,9 +3807,9 @@ package body Freeze is elsif (Is_Tagged_Type (R_Type) or else (Is_Access_Type (R_Type) - and then - Is_Tagged_Type - (Designated_Type (R_Type)))) + and then + Is_Tagged_Type + (Designated_Type (R_Type)))) and then Convention (E) = Convention_C and then not Has_Warnings_Off (E) and then not Has_Warnings_Off (R_Type) @@ -4118,13 +4109,8 @@ package body Freeze is -- Remaining step is to layout objects - if Ekind (E) = E_Variable - or else - Ekind (E) = E_Constant - or else - Ekind (E) = E_Loop_Parameter - or else - Is_Formal (E) + if Ekind_In (E, E_Variable, E_Constant, E_Loop_Parameter) + or else Is_Formal (E) then Layout_Object (E); end if; @@ -4449,8 +4435,7 @@ package body Freeze is elsif Is_Concurrent_Type (E) then if Present (Corresponding_Record_Type (E)) then - Freeze_And_Append - (Corresponding_Record_Type (E), N, Result); + Freeze_And_Append (Corresponding_Record_Type (E), N, Result); end if; Comp := First_Entity (E); @@ -4596,9 +4581,7 @@ package body Freeze is -- amendment type, so diagnosis is at the point of use and the -- type might be frozen later. - elsif E /= Base_Type (E) - or else Is_Derived_Type (E) - then + elsif E /= Base_Type (E) or else Is_Derived_Type (E) then null; else @@ -4813,8 +4796,7 @@ package body Freeze is -- be an array type, or a nonlimited record type). if Has_Private_Declaration (E) then - if (not Is_Record_Type (E) - or else not Is_Limited_View (E)) + if (not Is_Record_Type (E) or else not Is_Limited_View (E)) and then not Is_Private_Type (E) then Error_Msg_Name_1 := Name_Simple_Storage_Pool_Type; @@ -4845,7 +4827,8 @@ package body Freeze is -- Upon return, Pool_Op_Formal will be updated to the next -- formal, if any. - procedure Validate_Simple_Pool_Operation (Op_Name : Name_Id); + procedure Validate_Simple_Pool_Operation + (Op_Name : Name_Id); -- Search for and validate a simple pool operation with the -- name Op_Name. If the name is Allocate, then there must be -- exactly one such primitive operation for the simple pool @@ -6784,18 +6767,16 @@ package body Freeze is -- directly. if Nkind (Dcopy) = N_Identifier - or else Nkind (Dcopy) = N_Expanded_Name - or else Nkind (Dcopy) = N_Integer_Literal + or else Nkind_In (Dcopy, N_Expanded_Name, + N_Integer_Literal, + N_Character_Literal, + N_String_Literal) or else (Nkind (Dcopy) = N_Real_Literal and then not Vax_Float (Etype (Dcopy))) - or else Nkind (Dcopy) = N_Character_Literal - or else Nkind (Dcopy) = N_String_Literal - or else Known_Null (Dcopy) or else (Nkind (Dcopy) = N_Attribute_Reference - and then - Attribute_Name (Dcopy) = Name_Null_Parameter) + and then Attribute_Name (Dcopy) = Name_Null_Parameter) + or else Known_Null (Dcopy) then - -- If there is no default function, we must still do a full -- analyze call on the default value, to ensure that all error -- checks are performed, e.g. those associated with static diff --git a/gcc/ada/gnat_rm.texi b/gcc/ada/gnat_rm.texi index 146936ce4ab..9d270c92095 100644 --- a/gcc/ada/gnat_rm.texi +++ b/gcc/ada/gnat_rm.texi @@ -8897,8 +8897,9 @@ order as the parent type. If a component of @var{S} has itself a record or array type, then it shall also have a @code{Scalar_Storage_Order} attribute definition clause. In addition, -if the component does not start on a byte boundary, then the scalar storage -order specified for S and for the nested component type shall be identical. +if the component is a packed array, or does not start on a byte boundary, then +the scalar storage order specified for S and for the nested component type shall +be identical. If @var{S} appears as the type of a record or array component, the enclosing record or array shall also have a @code{Scalar_Storage_Order} attribute diff --git a/gcc/ada/par-ch4.adb b/gcc/ada/par-ch4.adb index 5981f01c8e7..ab66f5c850a 100644 --- a/gcc/ada/par-ch4.adb +++ b/gcc/ada/par-ch4.adb @@ -3078,6 +3078,7 @@ package body Ch4 is function P_If_Expression return Node_Id is Exprs : constant List_Id := New_List; Loc : constant Source_Ptr := Token_Ptr; + Cond : Node_Id; Expr : Node_Id; State : Saved_Scan_State; @@ -3085,9 +3086,17 @@ package body Ch4 is Inside_If_Expression := Inside_If_Expression + 1; Error_Msg_Ada_2012_Feature ("|if expression", Token_Ptr); Scan; -- past IF or ELSIF - Append_To (Exprs, P_Condition); - TF_Then; - Append_To (Exprs, P_Expression); + Cond := P_Condition; + + if Token = Tok_Then then + Scan; -- past THEN + Append_To (Exprs, Cond); + Append_To (Exprs, P_Expression); + + else + Error_Msg ("ELSIF should be ELSE", Loc); + return Cond; + end if; -- We now have scanned out IF expr THEN expr @@ -3110,7 +3119,14 @@ package body Ch4 is if Token = Tok_Elsif then Expr := P_If_Expression; - Set_Is_Elsif (Expr); + + if Nkind (Expr) = N_If_Expression then + Set_Is_Elsif (Expr); + + -- Otherwise, this is an incomplete ELSIF as reported earlier, + -- so treat the expression as a final ELSE for better recovery. + end if; + Append_To (Exprs, Expr); -- Scan out ELSE phrase if present diff --git a/gcc/ada/sem_attr.adb b/gcc/ada/sem_attr.adb index 1b585cb61fa..5727e6d0990 100644 --- a/gcc/ada/sem_attr.adb +++ b/gcc/ada/sem_attr.adb @@ -9788,8 +9788,9 @@ package body Sem_Attr is Object_Access_Level (P) > Deepest_Type_Access_Level (Btyp) and then Attr_Id = Attribute_Access then - -- In an instance, this is a runtime check, but one we - -- know will fail, so generate an appropriate warning. + -- In an instance, this is a runtime check, but one we know + -- will fail, so generate an appropriate warning. As usual, + -- this kind of warning is an error in SPARK mode. if In_Instance_Body then Error_Msg_Warn := SPARK_Mode /= On; diff --git a/gcc/ada/sem_ch12.adb b/gcc/ada/sem_ch12.adb index b59c895744c..6b9c5feffc7 100644 --- a/gcc/ada/sem_ch12.adb +++ b/gcc/ada/sem_ch12.adb @@ -13796,6 +13796,8 @@ package body Sem_Ch12 is (Gen_Unit : Entity_Id; Act_Unit : Entity_Id) is + Assertion_Status : constant Boolean := Assertions_Enabled; + begin -- Regardless of the current mode, predefined units are analyzed in the -- most current Ada mode, and earlier version Ada checks do not apply @@ -13807,6 +13809,16 @@ package body Sem_Ch12 is Renamings_Included => True) then Set_Opt_Config_Switches (True, Current_Sem_Unit = Main_Unit); + + -- In Ada2012 we may want to enable assertions in an instance of a + -- predefined unit, in which case we need to preserve the current + -- setting for the Assertions_Enabled flag. This will become more + -- critical when pre/postconditions are added to predefined units, + -- as is already the case for some numeric libraries. + + if Ada_Version >= Ada_2012 then + Assertions_Enabled := Assertion_Status; + end if; end if; Current_Instantiated_Parent := diff --git a/gcc/ada/sem_res.adb b/gcc/ada/sem_res.adb index c42a7fa3cbd..dbc13d34008 100644 --- a/gcc/ada/sem_res.adb +++ b/gcc/ada/sem_res.adb @@ -9069,6 +9069,8 @@ package body Sem_Res is T := Etype (P); end if; + -- Set flag for expander if discriminant check required + if Has_Discriminants (T) and then Ekind_In (Entity (S), E_Component, E_Discriminant) and then Present (Original_Record_Component (Entity (S))) |