-- C390003.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 for a subtype S of a tagged type T, S'Class denotes a -- class-wide subtype. Check that T'Tag denotes the tag of the type T, -- and that, for a class-wide tagged type X, X'Tag denotes the tag of X. -- Check that the tags of stand alone objects, record and array -- components, aggregates, and formal parameters identify their type. -- Check that the tag of a value of a formal parameter is that of the -- actual parameter, even if the actual is passed by a view conversion. -- -- TEST DESCRIPTION: -- This test defines a class hierarchy (based on C390002) and -- uses it to determine the correctness of the resulting tag -- information generated by the compiler. A type is defined in the -- class which contains components of the class as part of its -- definition. This is to reduce the overall number of types -- required, and to achieve the required nesting to accomplish -- this test. The model is that of a car carrier truck; both car -- and truck being in the class of Vehicle. -- -- Class Hierarchy: -- Vehicle - - - - - - - (Bicycle) -- / | \ / \ -- Truck Car Q_Machine Tandem Motorcycle -- | -- Auto_Carrier -- Contains: -- Auto_Carrier( Car ) -- Q_Machine( Car, Motorcycle ) -- -- -- -- CHANGE HISTORY: -- 06 Dec 94 SAIC ACVC 2.0 -- 19 Dec 94 SAIC Removed ARM references from objective text. -- 20 Dec 94 SAIC Replaced three unnecessary extension -- aggregates with simple aggregates. -- 16 Oct 95 SAIC Fixed bugs for ACVC 2.0.1 -- --! ----------------------------------------------------------------- C390003_1 with Ada.Tags; package C390003_1 is -- Vehicle type TC_Keys is (Veh, MC, Tand, Car, Q, Truk, Heavy); type States is (Good, Flat, Worn); type Wheel_List is array(Positive range <>) of States; type Object(Wheels: Positive) is tagged record Wheel_State : Wheel_List(1..Wheels); end record; procedure TC_Validate( It: Object; Key: TC_Keys ); procedure TC_Validate( It: Object'Class; The_Tag: Ada.Tags.Tag ); procedure Create( The_Vehicle : in out Object; Tyres : in States ); procedure Rotate( The_Vehicle : in out Object ); function Wheels( The_Vehicle : Object ) return Positive; end C390003_1; -- Vehicle; ----------------------------------------------------------------- C390003_2 with C390003_1; package C390003_2 is -- Motivators package Vehicle renames C390003_1; subtype Bicycle is Vehicle.Object(2); -- constrained subtype type Motorcycle is new Bicycle with record Displacement : Natural; end record; procedure TC_Validate( It: Motorcycle; Key: Vehicle.TC_Keys ); type Tandem is new Bicycle with null record; procedure TC_Validate( It: Tandem; Key: Vehicle.TC_Keys ); type Car is new Vehicle.Object(4) with -- extended, constrained record Displacement : Natural; end record; procedure TC_Validate( It: Car; Key: Vehicle.TC_Keys ); type Truck is new Vehicle.Object with -- extended, unconstrained record Tare : Natural; end record; procedure TC_Validate( It: Truck; Key: Vehicle.TC_Keys ); end C390003_2; -- Motivators; ----------------------------------------------------------------- C390003_3 with C390003_1; with C390003_2; package C390003_3 is -- Special_Trucks package Vehicle renames C390003_1; package Motivators renames C390003_2; Max_Cars_On_Vehicle : constant := 6; type Cargo_Index is range 0..Max_Cars_On_Vehicle; type Cargo is array(Cargo_Index range 1..Max_Cars_On_Vehicle) of Motivators.Car; type Auto_Carrier is new Motivators.Truck(18) with record Load_Count : Cargo_Index := 0; Payload : Cargo; end record; procedure TC_Validate( It: Auto_Carrier; Key: Vehicle.TC_Keys ); procedure Load ( The_Car : in Motivators.Car; Onto : in out Auto_Carrier); procedure Unload( The_Car : out Motivators.Car; Off_of : in out Auto_Carrier); end C390003_3; ----------------------------------------------------------------- C390003_4 with C390003_1; with C390003_2; package C390003_4 is -- James_Bond package Vehicle renames C390003_1; package Motivators renames C390003_2; type Q_Machine is new Vehicle.Object(4) with record Car_Part : Motivators.Car; Bike_Part : Motivators.Motorcycle; end record; procedure TC_Validate( It: Q_Machine; Key: Vehicle.TC_Keys ); end C390003_4; ----------------------------------------------------------------- C390003_1 with Report; with Ada.Tags; package body C390003_1 is -- Vehicle function "="(A,B: Ada.Tags.Tag) return Boolean renames Ada.Tags."="; procedure TC_Validate( It: Object; Key: TC_Keys ) is begin if Key /= Veh then Report.Failed("Expected Veh Key"); end if; end TC_Validate; procedure TC_Validate( It: Object'Class; The_Tag: Ada.Tags.Tag ) is begin if It'Tag /= The_Tag then Report.Failed("Unexpected Tag for classwide formal"); end if; end TC_Validate; procedure Create( The_Vehicle : in out Object; Tyres : in States ) is begin The_Vehicle.Wheel_State := ( others => Tyres ); end Create; function Wheels( The_Vehicle : Object ) return Positive is begin return The_Vehicle.Wheels; end Wheels; procedure Rotate( The_Vehicle : in out Object ) is Push : States; Pulled : States := The_Vehicle.Wheel_State(The_Vehicle.Wheel_State'Last); begin for Finger in The_Vehicle.Wheel_State'First..The_Vehicle.Wheel_State'Last loop Push := The_Vehicle.Wheel_State(Finger); The_Vehicle.Wheel_State(Finger) := Pulled; Pulled := Push; end loop; end Rotate; end C390003_1; -- Vehicle; ----------------------------------------------------------------- C390003_2 with Ada.Tags; with Report; package body C390003_2 is -- Motivators function "="(A,B: Ada.Tags.Tag) return Boolean renames Ada.Tags."="; function "="(A,B: Vehicle.TC_Keys) return Boolean renames Vehicle."="; procedure TC_Validate( It: Motorcycle; Key: Vehicle.TC_Keys ) is begin if Key /= Vehicle.MC then Report.Failed("Expected MC Key"); end if; end TC_Validate; procedure TC_Validate( It: Tandem; Key: Vehicle.TC_Keys ) is begin if Key /= Vehicle.Tand then Report.Failed("Expected Tand Key"); end if; end TC_Validate; procedure TC_Validate( It: Car; Key: Vehicle.TC_Keys ) is begin if Key /= Vehicle.Car then Report.Failed("Expected Car Key"); end if; end TC_Validate; procedure TC_Validate( It: Truck; Key: Vehicle.TC_Keys ) is begin if Key /= Vehicle.Truk then Report.Failed("Expected Truk Key"); end if; end TC_Validate; end C390003_2; -- Motivators; ----------------------------------------------------------------- C390003_3 with Ada.Tags; with Report; package body C390003_3 is -- Special_Trucks function "="(A,B: Ada.Tags.Tag) return Boolean renames Ada.Tags."="; function "="(A,B: Vehicle.TC_Keys) return Boolean renames Vehicle."="; procedure TC_Validate( It: Auto_Carrier; Key: Vehicle.TC_Keys ) is begin if Key /= Vehicle.Heavy then Report.Failed("Expected Heavy Key"); end if; end TC_Validate; procedure Load ( The_Car : in Motivators.Car; Onto : in out Auto_Carrier) is begin Onto.Load_Count := Onto.Load_Count +1; Onto.Payload(Onto.Load_Count) := The_Car; end Load; procedure Unload( The_Car : out Motivators.Car; Off_of : in out Auto_Carrier) is begin The_Car := Off_of.Payload(Off_of.Load_Count); Off_of.Load_Count := Off_of.Load_Count -1; end Unload; end C390003_3; ----------------------------------------------------------------- C390003_4 with Report, Ada.Tags; package body C390003_4 is -- James_Bond function "="(A,B: Ada.Tags.Tag) return Boolean renames Ada.Tags."="; function "="(A,B: Vehicle.TC_Keys) return Boolean renames Vehicle."="; procedure TC_Validate( It: Q_Machine; Key: Vehicle.TC_Keys ) is begin if Key /= Vehicle.Q then Report.Failed("Expected Q Key"); end if; end TC_Validate; end C390003_4; ------------------------------------------------------------------- C390003 with Report; with C390003_1; with C390003_2; with C390003_3; with C390003_4; procedure C390003 is package Vehicle renames C390003_1; use Vehicle; package Motivators renames C390003_2; package Special_Trucks renames C390003_3; package James_Bond renames C390003_4; -- The cast, in order of complexity: Pennys_Bike : Motivators.Bicycle; Weekender : Motivators.Tandem; Qs_Moped : Motivators.Motorcycle; Ms_Limo : Motivators.Car; Yard_Van : Motivators.Truck(8); Specter_X : Special_Trucks.Auto_Carrier; Gen_II : James_Bond.Q_Machine; -- Check compatibility with the corresponding class wide type. procedure Vehicle_Shop( It : in out Vehicle.Object'Class; Key : in Vehicle.TC_Keys ) is -- Check that Subtype'Class is defined for tagged subtypes. procedure Bike_Shop( Bike: in out Motivators.Bicycle'Class ) is begin -- Dispatch to appropriate TC_Validate Vehicle.TC_Validate( Bike, Key ); end Bike_Shop; begin Vehicle.TC_Validate( It, Key ); if Vehicle.Wheels( It ) = 2 then Bike_Shop( It ); -- only call Bike_Shop when It has 2 wheels end if; end Vehicle_Shop; begin -- Main test procedure. Report.Test ("C390003", "Check that for a subtype S of a tagged type " & "T, S'Class denotes a class-wide subtype. Check that " & "T'Tag denotes the tag of the type T, and that, for a " & "class-wide tagged type X, X'Tag denotes the tag of X. " & "Check that the tags of stand alone objects, record and " & "array components, aggregates, and formal parameters " & "identify their type. Check that the tag of a value of a " & "formal parameter is that of the actual parameter, even " & "if the actual is passed by a view conversion" ); -- Check that the tags of stand alone objects, record and array -- components, aggregates, and formal parameters identify their type. -- Check that the tag of a value of a formal parameter is that of the -- actual parameter, even if the actual is passed by a view conversion. Vehicle_Shop( Pennys_Bike, Veh ); Vehicle_Shop( Weekender, Tand ); Vehicle_Shop( Qs_Moped, MC ); Vehicle_Shop( Ms_Limo, Car ); Vehicle_Shop( Yard_Van, Truk ); Vehicle_Shop( Specter_X, Heavy ); Vehicle_Shop( Specter_X.Payload(1), Car ); Vehicle_Shop( Gen_II, Q ); Vehicle_Shop( Gen_II.Car_Part, Car ); Vehicle_Shop( Gen_II.Bike_Part, MC ); Vehicle.TC_Validate( Pennys_Bike, Vehicle.Object'Tag ); Vehicle.TC_Validate( Weekender, Motivators.Tandem'Tag ); Vehicle.TC_Validate( Qs_Moped, Motivators.Motorcycle'Tag ); Vehicle.TC_Validate( Ms_Limo, Motivators.Car'Tag ); Vehicle.TC_Validate( Yard_Van, Motivators.Truck'Tag ); Vehicle.TC_Validate( Specter_X, Special_Trucks.Auto_Carrier'Tag ); Vehicle.TC_Validate( Specter_X.Payload(1), Motivators.Car'Tag ); Vehicle.TC_Validate( Gen_II, James_Bond.Q_Machine'Tag ); Vehicle.TC_Validate( Gen_II.Car_Part, Motivators.Car'Tag ); Vehicle.TC_Validate( Gen_II.Bike_Part, Motivators.Motorcycle'Tag ); -- Check the tag generated for an aggregate. Rentals: declare Mikes_Rental : Vehicle.Object'Class := Vehicle.Object'( 3, (Good, Flat, Worn)); Diannes_Car : Vehicle.Object'Class := Motivators.Tandem'( Wheels => 2, Wheel_State => (Good, Good) ); Jims_Bike : Vehicle.Object'Class := Motivators.Motorcycle'( Pennys_Bike with Displacement => 350 ); Bills_Limo : Vehicle.Object'Class := Motivators.Car'( Wheels => 4, Wheel_State => (others => Good), Displacement => 282 ); Alans_Car : Vehicle.Object'Class := Motivators.Truck'( 18, (others => Worn), Tare => 5_500 ); Pats_Truck : Vehicle.Object'Class := Specter_X; Keiths_Car : Vehicle.Object'Class := Gen_II; Isaacs_Bus : Vehicle.Object'Class := Keiths_Car; begin Vehicle.TC_Validate( Mikes_Rental, Vehicle.Object'Tag ); Vehicle.TC_Validate( Diannes_Car, Motivators.Tandem'Tag ); Vehicle.TC_Validate( Jims_Bike, Motivators.Motorcycle'Tag ); Vehicle.TC_Validate( Bills_Limo, Motivators.Car'Tag ); Vehicle.TC_Validate( Alans_Car, Motivators.Truck'Tag ); Vehicle.TC_Validate( Pats_Truck, Special_Trucks.Auto_Carrier'Tag ); Vehicle.TC_Validate( Keiths_Car, James_Bond.Q_Machine'Tag ); end Rentals; -- Check the tag of parameters. -- Check that the tag is not affected by view conversion. Vehicle.TC_Validate( Vehicle.Object( Gen_II ), James_Bond.Q_Machine'Tag ); Vehicle.TC_Validate( Vehicle.Object( Ms_Limo ), Motivators.Car'Tag ); Vehicle.TC_Validate( Motivators.Bicycle( Weekender ), Motivators.Tandem'Tag ); Vehicle.TC_Validate( Motivators.Bicycle( Gen_II.Bike_Part ), Motivators.Motorcycle'Tag ); Report.Result; end C390003;