[Ada] AI12-0382: Loosen type-invariant overriding requirement of AI12-0042
gcc/ada/ * sem_ch3.adb (Check_Abstract_Overriding): Remove Scope comparison test from test related to initial implementation of AI12-0042, plus remove the related ??? comment. (Derive_Subprogram): Add test requiring that the type extension appear in the visible part of its enclosing package when checking the overriding requirement of 7.3.2(6.1/4), as clarified by AI12-0382.
This commit is contained in:
parent
df81923f6d
commit
faa163f737
@ -10763,12 +10763,7 @@ package body Sem_Ch3 is
|
|||||||
-- AI12-0042: Test for rule in 7.3.2(6.1/4), that requires overriding
|
-- AI12-0042: Test for rule in 7.3.2(6.1/4), that requires overriding
|
||||||
-- of a visible private primitive inherited from an ancestor with
|
-- of a visible private primitive inherited from an ancestor with
|
||||||
-- the aspect Type_Invariant'Class, unless the inherited primitive
|
-- the aspect Type_Invariant'Class, unless the inherited primitive
|
||||||
-- is abstract. (The test for the extension occurring in a different
|
-- is abstract.
|
||||||
-- scope than the ancestor is to avoid requiring overriding when
|
|
||||||
-- extending in the same scope, because the inherited primitive will
|
|
||||||
-- also be private in that case, which looks like an unhelpful
|
|
||||||
-- restriction that may break reasonable code, though the rule
|
|
||||||
-- appears to apply in the same-scope case as well???)
|
|
||||||
|
|
||||||
elsif not Is_Abstract_Subprogram (Subp)
|
elsif not Is_Abstract_Subprogram (Subp)
|
||||||
and then not Comes_From_Source (Subp) -- An inherited subprogram
|
and then not Comes_From_Source (Subp) -- An inherited subprogram
|
||||||
@ -10778,7 +10773,6 @@ package body Sem_Ch3 is
|
|||||||
and then Present (Get_Pragma (Etype (T), Pragma_Invariant))
|
and then Present (Get_Pragma (Etype (T), Pragma_Invariant))
|
||||||
and then Class_Present (Get_Pragma (Etype (T), Pragma_Invariant))
|
and then Class_Present (Get_Pragma (Etype (T), Pragma_Invariant))
|
||||||
and then Is_Private_Primitive (Alias_Subp)
|
and then Is_Private_Primitive (Alias_Subp)
|
||||||
and then Scope (Subp) /= Scope (Alias_Subp)
|
|
||||||
then
|
then
|
||||||
Error_Msg_NE
|
Error_Msg_NE
|
||||||
("inherited private primitive & must be overridden", T, Subp);
|
("inherited private primitive & must be overridden", T, Subp);
|
||||||
@ -15732,7 +15726,9 @@ package body Sem_Ch3 is
|
|||||||
-- AI12-0042: Set Requires_Overriding when a type extension
|
-- AI12-0042: Set Requires_Overriding when a type extension
|
||||||
-- inherits a private operation that is visible at the
|
-- inherits a private operation that is visible at the
|
||||||
-- point of extension (Has_Private_Ancestor is False) from
|
-- point of extension (Has_Private_Ancestor is False) from
|
||||||
-- an ancestor that has Type_Invariant'Class.
|
-- an ancestor that has Type_Invariant'Class, and when the
|
||||||
|
-- type extension is in a visible part (the latter as
|
||||||
|
-- clarified by AI12-0382).
|
||||||
|
|
||||||
or else
|
or else
|
||||||
(not Has_Private_Ancestor (Derived_Type)
|
(not Has_Private_Ancestor (Derived_Type)
|
||||||
@ -15742,7 +15738,8 @@ package body Sem_Ch3 is
|
|||||||
and then
|
and then
|
||||||
Class_Present
|
Class_Present
|
||||||
(Get_Pragma (Parent_Type, Pragma_Invariant))
|
(Get_Pragma (Parent_Type, Pragma_Invariant))
|
||||||
and then Is_Private_Primitive (Parent_Subp)))
|
and then Is_Private_Primitive (Parent_Subp)
|
||||||
|
and then In_Visible_Part (Scope (Derived_Type))))
|
||||||
|
|
||||||
and then No (Actual_Subp)
|
and then No (Actual_Subp)
|
||||||
then
|
then
|
||||||
|
Loading…
Reference in New Issue
Block a user