blob: d8f78779dee61e392d74952518a624e248236ee2 [file] [log] [blame]
-- CC51007.A
--
-- Grant of Unlimited Rights
--
-- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
-- F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained
-- unlimited rights in the software and documentation contained herein.
-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
-- this public release, the Government intends to confer upon all
-- recipients unlimited rights equal to those held by the Government.
-- These rights include rights to use, duplicate, release or disclose the
-- released technical data and computer software in whole or in part, in
-- any manner and for any purpose whatsoever, and to have or permit others
-- to do so.
--
-- DISCLAIMER
--
-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
-- PARTICULAR PURPOSE OF SAID MATERIAL.
--*
--
-- OBJECTIVE:
-- Check that a generic formal derived tagged type is a private extension.
-- Specifically, check that, for a generic formal derived type whose
-- ancestor type has abstract primitive subprograms, neither the formal
-- derived type nor its descendants need be abstract. Check that objects
-- and components of the formal derived type and its nonabstract
-- descendants may be declared and allocated, as may nonabstract
-- functions returning these types, and that aggregates of nonabstract
-- descendants of the formal derived type are legal. Check that calls to
-- the abstract primitive subprograms of the ancestor dispatch to the
-- bodies corresponding to the tag of the actual parameters.
--
-- TEST DESCRIPTION:
-- Although the ancestor type is abstract and has abstract primitive
-- subprograms, these subprograms, when inherited by a formal nonabstract
-- derived type, are not abstract, since the formal derived type is a
-- nonabstract private extension.
--
-- Thus, derivatives of the formal derived type need not be abstract,
-- and both the formal derived type and its derivatives are considered
-- nonabstract types.
--
-- This test verifies that the restrictions placed on abstract types do
-- not apply to the formal derived type or its derivatives. Specifically,
-- objects of, components of, allocators of, and nonabstract functions
-- returning the formal derived type or its derivatives are legal. In
-- addition, the test verifies that a call within the instance to a
-- primitive subprogram of the (abstract) ancestor type dispatches to
-- the body corresponding to the tag of the actual parameter.
--
--
-- CHANGE HISTORY:
-- 06 Dec 94 SAIC ACVC 2.0
-- 23 Dec 94 SAIC Deleted illegal extension aggregate. Corrected
-- dispatching call. Editorial changes to commentary.
-- 05 Nov 95 SAIC ACVC 2.0.1 fixes: Moved instantiation of CC51007_3
-- to library level.
-- 11 Aug 96 SAIC ACVC 2.1: Added pragma Elaborate to context
-- clauses of CC51007_1 and CC51007_4.
--
--!
package CC51007_0 is
Max_Length : constant := 10;
type Text is new String(1 .. Max_Length);
type Alert is abstract tagged record -- Root type of class
Message : Text := (others => '*'); -- (abstract).
end record;
procedure Handle (A: in out Alert) is abstract; -- Abstract dispatching
-- operation.
end CC51007_0;
-- No body for CC51007_0;
--===================================================================--
with CC51007_0;
with Ada.Calendar;
pragma Elaborate (Ada.Calendar);
package CC51007_1 is
type Low_Alert is new CC51007_0.Alert with record
Time_Of_Arrival : Ada.Calendar.Time := Ada.Calendar.Time_Of (1901, 8, 1);
end record;
procedure Handle (A: in out Low_Alert); -- Overrides parent's
-- implementation.
Low : Low_Alert;
end CC51007_1;
--===================================================================--
package body CC51007_1 is
procedure Handle (A: in out Low_Alert) is -- Artificial for
begin -- testing.
A.Time_Of_Arrival := Ada.Calendar.Time_Of (1984, 1, 1);
A.Message := "Low Alert!";
end Handle;
end CC51007_1;
--===================================================================--
with CC51007_1;
package CC51007_2 is
type Person is (OOD, CO, CinC);
type Medium_Alert is new CC51007_1.Low_Alert with record
Action_Officer : Person := OOD;
end record;
procedure Handle (A: in out Medium_Alert); -- Overrides parent's
-- implementation.
Med : Medium_Alert;
end CC51007_2;
--===================================================================--
with Ada.Calendar;
package body CC51007_2 is
procedure Handle (A: in out Medium_Alert) is -- Artificial for
begin -- testing.
A.Action_Officer := CO;
A.Time_Of_Arrival := Ada.Calendar.Time_Of (2001, 1, 1);
A.Message := "Med Alert!";
end Handle;
end CC51007_2;
--===================================================================--
with CC51007_0;
generic
type Alert_Type is new CC51007_0.Alert with private;
Initial_State : in Alert_Type;
package CC51007_3 is
function Clear_Message (A: Alert_Type) -- Function returning
return Alert_Type; -- formal type.
Max_Note : Natural := 10;
type Note is new String (1 .. Max_Note);
type Extended_Alert is new Alert_Type with record
Addendum : Note := (others => '*');
end record;
-- In instance, inherits version of Handle from
-- actual corresponding to formal type.
function Annotate_Alert (A: in Alert_Type'Class) -- Function returning
return Extended_Alert; -- derived type.
Init_Ext_Alert : constant Extended_Alert := -- Object declaration.
(Initial_State with Addendum => "----------"); -- Aggregate.
type Alert_Type_Ptr is access constant Alert_Type;
type Ext_Alert_Ptr is access Extended_Alert;
Init_Alert_Ptr : Alert_Type_Ptr :=
new Alert_Type'(Initial_State); -- Allocator.
Init_Ext_Alert_Ptr : Ext_Alert_Ptr :=
new Extended_Alert'(Init_Ext_Alert); -- Allocator.
type Alert_Pair is record
A : Alert_Type; -- Component.
EA : Extended_Alert; -- Component.
end record;
end CC51007_3;
--===================================================================--
package body CC51007_3 is
function Clear_Message (A: Alert_Type) return Alert_Type is
Temp : Alert_Type := A; -- Object declaration.
begin
Temp.Message := (others => '-');
return Temp;
end Clear_Message;
function Annotate_Alert (A: in Alert_Type'Class) return Extended_Alert is
Temp : Alert_Type'Class := A;
begin
Handle (Temp); -- Dispatching call to
-- operation of ancestor.
return (Alert_Type(Temp) with Addendum => "No comment");
end Annotate_Alert;
end CC51007_3;
--===================================================================--
with CC51007_1;
with CC51007_3;
pragma Elaborate (CC51007_3);
package CC51007_4 is new CC51007_3 (CC51007_1.Low_Alert, CC51007_1.Low);
--===================================================================--
with CC51007_1;
with CC51007_2;
with CC51007_3;
with CC51007_4;
with Ada.Calendar;
with Report;
procedure CC51007 is
package Alert_Support renames CC51007_4;
Ext : Alert_Support.Extended_Alert;
TC_Result : Alert_Support.Extended_Alert;
TC_Low_Expected : constant Alert_Support.Extended_Alert :=
(Time_Of_Arrival => Ada.Calendar.Time_Of (1984, 1, 1),
Message => "Low Alert!",
Addendum => "No comment");
TC_Med_Expected : constant Alert_Support.Extended_Alert :=
(Time_Of_Arrival => Ada.Calendar.Time_Of (2001, 1, 1),
Message => "Med Alert!",
Addendum => "No comment");
TC_Ext_Expected : constant Alert_Support.Extended_Alert := TC_Low_Expected;
use type Alert_Support.Extended_Alert;
begin
Report.Test ("CC51007", "Check that, for a generic formal derived type " &
"whose ancestor type has abstract primitive subprograms, " &
"neither the formal derived type nor its descendants need " &
"be abstract, and that objects of, components of, " &
"allocators of, aggregates of, and nonabstract functions " &
"returning these types are legal. Check that calls to the " &
"abstract primitive subprograms of the ancestor dispatch " &
"to the bodies corresponding to the tag of the actual " &
"parameters");
TC_Result := Alert_Support.Annotate_Alert (CC51007_1.Low); -- Dispatching
-- call.
if TC_Result /= TC_Low_Expected then
Report.Failed ("Wrong results from dispatching call (Low_Alert)");
end if;
TC_Result := Alert_Support.Annotate_Alert (CC51007_2.Med); -- Dispatching
-- call.
if TC_Result /= TC_Med_Expected then
Report.Failed ("Wrong results from dispatching call (Medium_Alert)");
end if;
TC_Result := Alert_Support.Annotate_Alert (Ext); -- Results in dispatching
-- call.
if TC_Result /= TC_Ext_Expected then
Report.Failed ("Wrong results from dispatching call (Extended_Alert)");
end if;
Report.Result;
end CC51007;