-- C371002.A
|
-- C371002.A
|
--
|
--
|
-- Grant of Unlimited Rights
|
-- Grant of Unlimited Rights
|
--
|
--
|
-- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
|
-- 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
|
-- 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 in the software and documentation contained herein.
|
-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
|
-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
|
-- this public release, the Government intends to confer upon all
|
-- this public release, the Government intends to confer upon all
|
-- recipients unlimited rights equal to those held by the Government.
|
-- recipients unlimited rights equal to those held by the Government.
|
-- These rights include rights to use, duplicate, release or disclose the
|
-- These rights include rights to use, duplicate, release or disclose the
|
-- released technical data and computer software in whole or in part, in
|
-- 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
|
-- any manner and for any purpose whatsoever, and to have or permit others
|
-- to do so.
|
-- to do so.
|
--
|
--
|
-- DISCLAIMER
|
-- DISCLAIMER
|
--
|
--
|
-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
|
-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
|
-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
|
-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
|
-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
|
-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
|
-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
|
-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
|
-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
|
-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
|
-- PARTICULAR PURPOSE OF SAID MATERIAL.
|
-- PARTICULAR PURPOSE OF SAID MATERIAL.
|
--*
|
--*
|
--
|
--
|
-- OBJECTIVE:
|
-- OBJECTIVE:
|
-- Check that if a discriminant constraint depends on a discriminant,
|
-- Check that if a discriminant constraint depends on a discriminant,
|
-- the evaluation of the expressions in the constraint is deferred until
|
-- the evaluation of the expressions in the constraint is deferred until
|
-- an object of the subtype is created. Check for cases of records.
|
-- an object of the subtype is created. Check for cases of records.
|
--
|
--
|
-- TEST DESCRIPTION:
|
-- TEST DESCRIPTION:
|
-- This transition test defines record types with discriminant components
|
-- This transition test defines record types with discriminant components
|
-- which depend on the discriminants. The discriminants are calculated
|
-- which depend on the discriminants. The discriminants are calculated
|
-- by function calls. The test verifies that Constraint_Error is raised
|
-- by function calls. The test verifies that Constraint_Error is raised
|
-- during the object creations when values of discriminants are
|
-- during the object creations when values of discriminants are
|
-- incompatible with the subtypes.
|
-- incompatible with the subtypes.
|
--
|
--
|
-- Inspired by C37213A.ADA, C37213C.ADA, C37215A.ADA and C37215C.ADA.
|
-- Inspired by C37213A.ADA, C37213C.ADA, C37215A.ADA and C37215C.ADA.
|
--
|
--
|
--
|
--
|
-- CHANGE HISTORY:
|
-- CHANGE HISTORY:
|
-- 05 Apr 96 SAIC Initial version for ACVC 2.1.
|
-- 05 Apr 96 SAIC Initial version for ACVC 2.1.
|
--
|
--
|
--!
|
--!
|
|
|
with Report;
|
with Report;
|
|
|
procedure C371002 is
|
procedure C371002 is
|
|
|
subtype Small_Int is Integer range 1..10;
|
subtype Small_Int is Integer range 1..10;
|
|
|
type Rec_W_Disc (Disc1, Disc2 : Small_Int) is
|
type Rec_W_Disc (Disc1, Disc2 : Small_Int) is
|
record
|
record
|
Str1 : String (1 .. Disc1) := (others => '*');
|
Str1 : String (1 .. Disc1) := (others => '*');
|
Str2 : String (1 .. Disc2) := (others => '*');
|
Str2 : String (1 .. Disc2) := (others => '*');
|
end record;
|
end record;
|
|
|
type My_Array is array (Small_Int range <>) of Integer;
|
type My_Array is array (Small_Int range <>) of Integer;
|
|
|
Func1_Cons : Integer := 0;
|
Func1_Cons : Integer := 0;
|
|
|
---------------------------------------------------------
|
---------------------------------------------------------
|
function Chk (Cons : Integer;
|
function Chk (Cons : Integer;
|
Value : Integer;
|
Value : Integer;
|
Message : String) return Boolean is
|
Message : String) return Boolean is
|
begin
|
begin
|
if Cons /= Value then
|
if Cons /= Value then
|
Report.Failed (Message & ": Func1_Cons is " &
|
Report.Failed (Message & ": Func1_Cons is " &
|
Integer'Image(Func1_Cons));
|
Integer'Image(Func1_Cons));
|
end if;
|
end if;
|
return True;
|
return True;
|
end Chk;
|
end Chk;
|
|
|
---------------------------------------------------------
|
---------------------------------------------------------
|
function Func1 return Integer is
|
function Func1 return Integer is
|
begin
|
begin
|
Func1_Cons := Func1_Cons + Report.Ident_Int(1);
|
Func1_Cons := Func1_Cons + Report.Ident_Int(1);
|
return Func1_Cons;
|
return Func1_Cons;
|
end Func1;
|
end Func1;
|
|
|
begin
|
begin
|
Report.Test ("C371002", "Check that if a discriminant constraint " &
|
Report.Test ("C371002", "Check that if a discriminant constraint " &
|
"depends on a discriminant, the evaluation of the " &
|
"depends on a discriminant, the evaluation of the " &
|
"expressions in the constraint is deferred until " &
|
"expressions in the constraint is deferred until " &
|
"object declarations");
|
"object declarations");
|
|
|
---------------------------------------------------------
|
---------------------------------------------------------
|
declare
|
declare
|
type Rec1 (D3 : Integer) is
|
type Rec1 (D3 : Integer) is
|
record
|
record
|
C1 : Rec_W_Disc (D3, Func1); -- Func1 evaluated, value 1.
|
C1 : Rec_W_Disc (D3, Func1); -- Func1 evaluated, value 1.
|
end record;
|
end record;
|
|
|
Chk1 : Boolean := Chk (Func1_Cons, 1,
|
Chk1 : Boolean := Chk (Func1_Cons, 1,
|
"Func1 not evaluated for Rec1");
|
"Func1 not evaluated for Rec1");
|
|
|
Obj1 : Rec1 (1); -- Func1 not evaluated again.
|
Obj1 : Rec1 (1); -- Func1 not evaluated again.
|
Obj2 : Rec1 (2); -- Func1 not evaluated again.
|
Obj2 : Rec1 (2); -- Func1 not evaluated again.
|
|
|
Chk2 : Boolean := Chk (Func1_Cons, 1,
|
Chk2 : Boolean := Chk (Func1_Cons, 1,
|
"Func1 evaluated too many times");
|
"Func1 evaluated too many times");
|
begin
|
begin
|
if Obj1 /= (D3 => 1,
|
if Obj1 /= (D3 => 1,
|
C1 => (Disc1 => 1,
|
C1 => (Disc1 => 1,
|
Disc2 => 1,
|
Disc2 => 1,
|
Str1 => (others => '*'),
|
Str1 => (others => '*'),
|
Str2 => (others => '*'))) or
|
Str2 => (others => '*'))) or
|
Obj2 /= (D3 => 2,
|
Obj2 /= (D3 => 2,
|
C1 => (Disc1 => 2,
|
C1 => (Disc1 => 2,
|
Disc2 => 1,
|
Disc2 => 1,
|
Str1 => (others => '*'),
|
Str1 => (others => '*'),
|
Str2 => (others => '*'))) then
|
Str2 => (others => '*'))) then
|
Report.Failed ("Obj1 & Obj2 - Discriminant values not correct");
|
Report.Failed ("Obj1 & Obj2 - Discriminant values not correct");
|
end if;
|
end if;
|
end;
|
end;
|
|
|
---------------------------------------------------------
|
---------------------------------------------------------
|
Func1_Cons := -11;
|
Func1_Cons := -11;
|
|
|
declare
|
declare
|
type Rec_Of_Rec_01 (D3 : Integer) is
|
type Rec_Of_Rec_01 (D3 : Integer) is
|
record
|
record
|
C1 : Rec_W_Disc (D3, Func1); -- Func1 evaluated, value -10.
|
C1 : Rec_W_Disc (D3, Func1); -- Func1 evaluated, value -10.
|
end record; -- Constraint_Error not raised.
|
end record; -- Constraint_Error not raised.
|
|
|
type Rec_Of_MyArr_01 (D3 : Integer) is
|
type Rec_Of_MyArr_01 (D3 : Integer) is
|
record
|
record
|
C1 : My_Array (Func1 .. D3); -- Func1 evaluated, value -9.
|
C1 : My_Array (Func1 .. D3); -- Func1 evaluated, value -9.
|
end record; -- Constraint_Error not raised.
|
end record; -- Constraint_Error not raised.
|
|
|
type Rec_Of_Rec_02 (D3 : Integer) is
|
type Rec_Of_Rec_02 (D3 : Integer) is
|
record
|
record
|
C1 : Rec_W_Disc (D3, 1);
|
C1 : Rec_W_Disc (D3, 1);
|
end record;
|
end record;
|
|
|
type Rec_Of_MyArr_02 (D3 : Integer) is
|
type Rec_Of_MyArr_02 (D3 : Integer) is
|
record
|
record
|
C1 : My_Array (D3 .. 1);
|
C1 : My_Array (D3 .. 1);
|
end record;
|
end record;
|
|
|
begin
|
begin
|
|
|
---------------------------------------------------------
|
---------------------------------------------------------
|
begin
|
begin
|
declare
|
declare
|
Obj3 : Rec_Of_Rec_01(1); -- Constraint_Error raised.
|
Obj3 : Rec_Of_Rec_01(1); -- Constraint_Error raised.
|
begin
|
begin
|
Report.Failed ("Obj3 - Constraint_Error should be raised");
|
Report.Failed ("Obj3 - Constraint_Error should be raised");
|
if Obj3 /= (1, (1, 1, others => (others => '*'))) then
|
if Obj3 /= (1, (1, 1, others => (others => '*'))) then
|
Report.Comment ("Obj3 - Shouldn't get here");
|
Report.Comment ("Obj3 - Shouldn't get here");
|
end if;
|
end if;
|
end;
|
end;
|
|
|
exception
|
exception
|
when Constraint_Error => -- Exception expected.
|
when Constraint_Error => -- Exception expected.
|
null;
|
null;
|
when others =>
|
when others =>
|
Report.Failed ("Obj3 - others exception raised");
|
Report.Failed ("Obj3 - others exception raised");
|
end;
|
end;
|
|
|
---------------------------------------------------------
|
---------------------------------------------------------
|
begin
|
begin
|
declare
|
declare
|
subtype Subtype_Rec is Rec_Of_Rec_01(1);
|
subtype Subtype_Rec is Rec_Of_Rec_01(1);
|
-- No Constraint_Error raised.
|
-- No Constraint_Error raised.
|
begin
|
begin
|
declare
|
declare
|
Obj4 : Subtype_Rec; -- Constraint_Error raised.
|
Obj4 : Subtype_Rec; -- Constraint_Error raised.
|
begin
|
begin
|
Report.Failed ("Obj4 - Constraint_Error should be raised");
|
Report.Failed ("Obj4 - Constraint_Error should be raised");
|
if Obj4 /= (D3 => 1,
|
if Obj4 /= (D3 => 1,
|
C1 => (Disc1 => 1,
|
C1 => (Disc1 => 1,
|
Disc2 => 1,
|
Disc2 => 1,
|
Str1 => (others => '*'),
|
Str1 => (others => '*'),
|
Str2 => (others => '*'))) then
|
Str2 => (others => '*'))) then
|
Report.Comment ("Obj4 - Shouldn't get here");
|
Report.Comment ("Obj4 - Shouldn't get here");
|
end if;
|
end if;
|
end;
|
end;
|
|
|
exception
|
exception
|
when Constraint_Error => -- Exception expected.
|
when Constraint_Error => -- Exception expected.
|
null;
|
null;
|
when others =>
|
when others =>
|
Report.Failed ("Obj4 - others exception raised");
|
Report.Failed ("Obj4 - others exception raised");
|
end;
|
end;
|
|
|
exception
|
exception
|
when Constraint_Error =>
|
when Constraint_Error =>
|
Report.Failed ("Subtype_Rec - Constraint_Error raised");
|
Report.Failed ("Subtype_Rec - Constraint_Error raised");
|
when others =>
|
when others =>
|
Report.Failed ("Subtype_Rec - others exception raised");
|
Report.Failed ("Subtype_Rec - others exception raised");
|
end;
|
end;
|
|
|
---------------------------------------------------------
|
---------------------------------------------------------
|
begin
|
begin
|
declare
|
declare
|
type Arr is array (1..5) -- No Constraint_Error raised.
|
type Arr is array (1..5) -- No Constraint_Error raised.
|
of Rec_Of_Rec_01(1);
|
of Rec_Of_Rec_01(1);
|
|
|
begin
|
begin
|
declare
|
declare
|
Obj5 : Arr; -- Constraint_Error raised.
|
Obj5 : Arr; -- Constraint_Error raised.
|
begin
|
begin
|
Report.Failed ("Obj5 - Constraint_Error should be raised");
|
Report.Failed ("Obj5 - Constraint_Error should be raised");
|
if Obj5 /= (1..5 => (1, (1, 1, others => (others => '*')))) then
|
if Obj5 /= (1..5 => (1, (1, 1, others => (others => '*')))) then
|
Report.Comment ("Obj5 - Shouldn't get here");
|
Report.Comment ("Obj5 - Shouldn't get here");
|
end if;
|
end if;
|
end;
|
end;
|
|
|
exception
|
exception
|
when Constraint_Error => -- Exception expected.
|
when Constraint_Error => -- Exception expected.
|
null;
|
null;
|
when others =>
|
when others =>
|
Report.Failed ("Obj5 - others exception raised");
|
Report.Failed ("Obj5 - others exception raised");
|
end;
|
end;
|
|
|
exception
|
exception
|
when Constraint_Error =>
|
when Constraint_Error =>
|
Report.Failed ("Arr - Constraint_Error raised");
|
Report.Failed ("Arr - Constraint_Error raised");
|
when others =>
|
when others =>
|
Report.Failed ("Arr - others exception raised");
|
Report.Failed ("Arr - others exception raised");
|
end;
|
end;
|
|
|
---------------------------------------------------------
|
---------------------------------------------------------
|
begin
|
begin
|
declare
|
declare
|
type Rec_Of_Rec_Of_MyArr is
|
type Rec_Of_Rec_Of_MyArr is
|
record
|
record
|
C1 : Rec_Of_MyArr_01(1); -- No Constraint_Error raised.
|
C1 : Rec_Of_MyArr_01(1); -- No Constraint_Error raised.
|
end record;
|
end record;
|
begin
|
begin
|
declare
|
declare
|
Obj6 : Rec_Of_Rec_Of_MyArr; -- Constraint_Error raised.
|
Obj6 : Rec_Of_Rec_Of_MyArr; -- Constraint_Error raised.
|
begin
|
begin
|
Report.Failed ("Obj6 - Constraint_Error should be raised");
|
Report.Failed ("Obj6 - Constraint_Error should be raised");
|
if Obj6 /= (C1 => (1, (1, 1))) then
|
if Obj6 /= (C1 => (1, (1, 1))) then
|
Report.Comment ("Obj6 - Shouldn't get here");
|
Report.Comment ("Obj6 - Shouldn't get here");
|
end if;
|
end if;
|
end;
|
end;
|
|
|
exception
|
exception
|
when Constraint_Error => -- Exception expected.
|
when Constraint_Error => -- Exception expected.
|
null;
|
null;
|
when others =>
|
when others =>
|
Report.Failed ("Obj6 - others exception raised");
|
Report.Failed ("Obj6 - others exception raised");
|
end;
|
end;
|
|
|
exception
|
exception
|
when Constraint_Error =>
|
when Constraint_Error =>
|
Report.Failed ("Rec_Of_Rec_Of_MyArr - Constraint_Error raised");
|
Report.Failed ("Rec_Of_Rec_Of_MyArr - Constraint_Error raised");
|
when others =>
|
when others =>
|
Report.Failed ("Rec_Of_Rec_Of_MyArr - others exception raised");
|
Report.Failed ("Rec_Of_Rec_Of_MyArr - others exception raised");
|
end;
|
end;
|
|
|
---------------------------------------------------------
|
---------------------------------------------------------
|
begin
|
begin
|
declare
|
declare
|
type New_Rec is
|
type New_Rec is
|
new Rec_Of_MyArr_01(1); -- No Constraint_Error raised.
|
new Rec_Of_MyArr_01(1); -- No Constraint_Error raised.
|
|
|
begin
|
begin
|
declare
|
declare
|
Obj7 : New_Rec; -- Constraint_Error raised.
|
Obj7 : New_Rec; -- Constraint_Error raised.
|
begin
|
begin
|
Report.Failed ("Obj7 - Constraint_Error should be raised");
|
Report.Failed ("Obj7 - Constraint_Error should be raised");
|
if Obj7 /= (1, (1, 1)) then
|
if Obj7 /= (1, (1, 1)) then
|
Report.Comment ("Obj7 - Shouldn't get here");
|
Report.Comment ("Obj7 - Shouldn't get here");
|
end if;
|
end if;
|
end;
|
end;
|
|
|
exception
|
exception
|
when Constraint_Error => -- Exception expected.
|
when Constraint_Error => -- Exception expected.
|
null;
|
null;
|
when others =>
|
when others =>
|
Report.Failed ("Obj7 - others exception raised");
|
Report.Failed ("Obj7 - others exception raised");
|
end;
|
end;
|
|
|
exception
|
exception
|
when Constraint_Error =>
|
when Constraint_Error =>
|
Report.Failed ("New_Rec - Constraint_Error raised");
|
Report.Failed ("New_Rec - Constraint_Error raised");
|
when others =>
|
when others =>
|
Report.Failed ("New_Rec - others exception raised");
|
Report.Failed ("New_Rec - others exception raised");
|
end;
|
end;
|
|
|
---------------------------------------------------------
|
---------------------------------------------------------
|
begin
|
begin
|
declare
|
declare
|
type Acc_Rec is
|
type Acc_Rec is
|
access Rec_Of_Rec_02 (Report.Ident_Int(0));
|
access Rec_Of_Rec_02 (Report.Ident_Int(0));
|
-- No Constraint_Error raised.
|
-- No Constraint_Error raised.
|
begin
|
begin
|
declare
|
declare
|
Obj8 : Acc_Rec; -- No Constraint_Error raised.
|
Obj8 : Acc_Rec; -- No Constraint_Error raised.
|
|
|
begin
|
begin
|
Obj8 := new Rec_Of_Rec_02 (Report.Ident_Int(0));
|
Obj8 := new Rec_Of_Rec_02 (Report.Ident_Int(0));
|
-- Constraint_Error raised.
|
-- Constraint_Error raised.
|
|
|
Report.Failed ("Obj8 - Constraint_Error should be raised");
|
Report.Failed ("Obj8 - Constraint_Error should be raised");
|
if Obj8.all /= (D3 => 1,
|
if Obj8.all /= (D3 => 1,
|
C1 => (Disc1 => 1,
|
C1 => (Disc1 => 1,
|
Disc2 => 1,
|
Disc2 => 1,
|
Str1 => (others => '*'),
|
Str1 => (others => '*'),
|
Str2 => (others => '*'))) then
|
Str2 => (others => '*'))) then
|
Report.Comment ("Obj8 - Shouldn't get here");
|
Report.Comment ("Obj8 - Shouldn't get here");
|
end if;
|
end if;
|
end;
|
end;
|
|
|
exception
|
exception
|
when Constraint_Error => -- Exception expected.
|
when Constraint_Error => -- Exception expected.
|
null;
|
null;
|
when others =>
|
when others =>
|
Report.Failed ("Obj8 - others exception raised");
|
Report.Failed ("Obj8 - others exception raised");
|
end;
|
end;
|
|
|
exception
|
exception
|
when Constraint_Error =>
|
when Constraint_Error =>
|
Report.Failed ("Acc_Rec - Constraint_Error raised");
|
Report.Failed ("Acc_Rec - Constraint_Error raised");
|
when others =>
|
when others =>
|
Report.Failed ("Acc_Rec - others exception raised");
|
Report.Failed ("Acc_Rec - others exception raised");
|
end;
|
end;
|
|
|
---------------------------------------------------------
|
---------------------------------------------------------
|
begin
|
begin
|
declare
|
declare
|
type Acc_Rec_MyArr is access
|
type Acc_Rec_MyArr is access
|
Rec_Of_MyArr_02; -- No Constraint_Error
|
Rec_Of_MyArr_02; -- No Constraint_Error
|
-- raised for either
|
-- raised for either
|
Obj9 : Acc_Rec_MyArr; -- declaration.
|
Obj9 : Acc_Rec_MyArr; -- declaration.
|
|
|
begin
|
begin
|
Obj9 := new Rec_Of_MyArr_02 (Report.Ident_Int(0));
|
Obj9 := new Rec_Of_MyArr_02 (Report.Ident_Int(0));
|
-- Constraint_Error raised.
|
-- Constraint_Error raised.
|
|
|
Report.Failed ("Obj9 - Constraint_Error should be raised");
|
Report.Failed ("Obj9 - Constraint_Error should be raised");
|
|
|
if Obj9.all /= (1, (1, 1)) then
|
if Obj9.all /= (1, (1, 1)) then
|
Report.Comment ("Obj9 - Shouldn't get here");
|
Report.Comment ("Obj9 - Shouldn't get here");
|
end if;
|
end if;
|
|
|
exception
|
exception
|
when Constraint_Error => -- Exception expected.
|
when Constraint_Error => -- Exception expected.
|
null;
|
null;
|
when others =>
|
when others =>
|
Report.Failed ("Obj9 - others exception raised");
|
Report.Failed ("Obj9 - others exception raised");
|
end;
|
end;
|
|
|
exception
|
exception
|
when Constraint_Error =>
|
when Constraint_Error =>
|
Report.Failed ("Acc_Rec_MyArr - Constraint_Error raised");
|
Report.Failed ("Acc_Rec_MyArr - Constraint_Error raised");
|
when others =>
|
when others =>
|
Report.Failed ("Acc_Rec_MyArr - others exception raised");
|
Report.Failed ("Acc_Rec_MyArr - others exception raised");
|
end;
|
end;
|
|
|
end;
|
end;
|
|
|
Report.Result;
|
Report.Result;
|
|
|
exception
|
exception
|
when others =>
|
when others =>
|
Report.Failed ("Discriminant value checked too soon");
|
Report.Failed ("Discriminant value checked too soon");
|
Report.Result;
|
Report.Result;
|
|
|
end C371002;
|
end C371002;
|
|
|