aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/ada/acats/tests/c3/c371002.a
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/ada/acats/tests/c3/c371002.a')
-rw-r--r--gcc/testsuite/ada/acats/tests/c3/c371002.a364
1 files changed, 0 insertions, 364 deletions
diff --git a/gcc/testsuite/ada/acats/tests/c3/c371002.a b/gcc/testsuite/ada/acats/tests/c3/c371002.a
deleted file mode 100644
index ea532550cd8..00000000000
--- a/gcc/testsuite/ada/acats/tests/c3/c371002.a
+++ /dev/null
@@ -1,364 +0,0 @@
--- C371002.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 if a discriminant constraint depends on a discriminant,
--- the evaluation of the expressions in the constraint is deferred until
--- an object of the subtype is created. Check for cases of records.
---
--- TEST DESCRIPTION:
--- This transition test defines record types with discriminant components
--- which depend on the discriminants. The discriminants are calculated
--- by function calls. The test verifies that Constraint_Error is raised
--- during the object creations when values of discriminants are
--- incompatible with the subtypes.
---
--- Inspired by C37213A.ADA, C37213C.ADA, C37215A.ADA and C37215C.ADA.
---
---
--- CHANGE HISTORY:
--- 05 Apr 96 SAIC Initial version for ACVC 2.1.
---
---!
-
-with Report;
-
-procedure C371002 is
-
- subtype Small_Int is Integer range 1..10;
-
- type Rec_W_Disc (Disc1, Disc2 : Small_Int) is
- record
- Str1 : String (1 .. Disc1) := (others => '*');
- Str2 : String (1 .. Disc2) := (others => '*');
- end record;
-
- type My_Array is array (Small_Int range <>) of Integer;
-
- Func1_Cons : Integer := 0;
-
- ---------------------------------------------------------
- function Chk (Cons : Integer;
- Value : Integer;
- Message : String) return Boolean is
- begin
- if Cons /= Value then
- Report.Failed (Message & ": Func1_Cons is " &
- Integer'Image(Func1_Cons));
- end if;
- return True;
- end Chk;
-
- ---------------------------------------------------------
- function Func1 return Integer is
- begin
- Func1_Cons := Func1_Cons + Report.Ident_Int(1);
- return Func1_Cons;
- end Func1;
-
-begin
- Report.Test ("C371002", "Check that if a discriminant constraint " &
- "depends on a discriminant, the evaluation of the " &
- "expressions in the constraint is deferred until " &
- "object declarations");
-
- ---------------------------------------------------------
- declare
- type Rec1 (D3 : Integer) is
- record
- C1 : Rec_W_Disc (D3, Func1); -- Func1 evaluated, value 1.
- end record;
-
- Chk1 : Boolean := Chk (Func1_Cons, 1,
- "Func1 not evaluated for Rec1");
-
- Obj1 : Rec1 (1); -- Func1 not evaluated again.
- Obj2 : Rec1 (2); -- Func1 not evaluated again.
-
- Chk2 : Boolean := Chk (Func1_Cons, 1,
- "Func1 evaluated too many times");
- begin
- if Obj1 /= (D3 => 1,
- C1 => (Disc1 => 1,
- Disc2 => 1,
- Str1 => (others => '*'),
- Str2 => (others => '*'))) or
- Obj2 /= (D3 => 2,
- C1 => (Disc1 => 2,
- Disc2 => 1,
- Str1 => (others => '*'),
- Str2 => (others => '*'))) then
- Report.Failed ("Obj1 & Obj2 - Discriminant values not correct");
- end if;
- end;
-
- ---------------------------------------------------------
- Func1_Cons := -11;
-
- declare
- type Rec_Of_Rec_01 (D3 : Integer) is
- record
- C1 : Rec_W_Disc (D3, Func1); -- Func1 evaluated, value -10.
- end record; -- Constraint_Error not raised.
-
- type Rec_Of_MyArr_01 (D3 : Integer) is
- record
- C1 : My_Array (Func1 .. D3); -- Func1 evaluated, value -9.
- end record; -- Constraint_Error not raised.
-
- type Rec_Of_Rec_02 (D3 : Integer) is
- record
- C1 : Rec_W_Disc (D3, 1);
- end record;
-
- type Rec_Of_MyArr_02 (D3 : Integer) is
- record
- C1 : My_Array (D3 .. 1);
- end record;
-
- begin
-
- ---------------------------------------------------------
- begin
- declare
- Obj3 : Rec_Of_Rec_01(1); -- Constraint_Error raised.
- begin
- Report.Failed ("Obj3 - Constraint_Error should be raised");
- if Obj3 /= (1, (1, 1, others => (others => '*'))) then
- Report.Comment ("Obj3 - Shouldn't get here");
- end if;
- end;
-
- exception
- when Constraint_Error => -- Exception expected.
- null;
- when others =>
- Report.Failed ("Obj3 - others exception raised");
- end;
-
- ---------------------------------------------------------
- begin
- declare
- subtype Subtype_Rec is Rec_Of_Rec_01(1);
- -- No Constraint_Error raised.
- begin
- declare
- Obj4 : Subtype_Rec; -- Constraint_Error raised.
- begin
- Report.Failed ("Obj4 - Constraint_Error should be raised");
- if Obj4 /= (D3 => 1,
- C1 => (Disc1 => 1,
- Disc2 => 1,
- Str1 => (others => '*'),
- Str2 => (others => '*'))) then
- Report.Comment ("Obj4 - Shouldn't get here");
- end if;
- end;
-
- exception
- when Constraint_Error => -- Exception expected.
- null;
- when others =>
- Report.Failed ("Obj4 - others exception raised");
- end;
-
- exception
- when Constraint_Error =>
- Report.Failed ("Subtype_Rec - Constraint_Error raised");
- when others =>
- Report.Failed ("Subtype_Rec - others exception raised");
- end;
-
- ---------------------------------------------------------
- begin
- declare
- type Arr is array (1..5) -- No Constraint_Error raised.
- of Rec_Of_Rec_01(1);
-
- begin
- declare
- Obj5 : Arr; -- Constraint_Error raised.
- begin
- Report.Failed ("Obj5 - Constraint_Error should be raised");
- if Obj5 /= (1..5 => (1, (1, 1, others => (others => '*')))) then
- Report.Comment ("Obj5 - Shouldn't get here");
- end if;
- end;
-
- exception
- when Constraint_Error => -- Exception expected.
- null;
- when others =>
- Report.Failed ("Obj5 - others exception raised");
- end;
-
- exception
- when Constraint_Error =>
- Report.Failed ("Arr - Constraint_Error raised");
- when others =>
- Report.Failed ("Arr - others exception raised");
- end;
-
- ---------------------------------------------------------
- begin
- declare
- type Rec_Of_Rec_Of_MyArr is
- record
- C1 : Rec_Of_MyArr_01(1); -- No Constraint_Error raised.
- end record;
- begin
- declare
- Obj6 : Rec_Of_Rec_Of_MyArr; -- Constraint_Error raised.
- begin
- Report.Failed ("Obj6 - Constraint_Error should be raised");
- if Obj6 /= (C1 => (1, (1, 1))) then
- Report.Comment ("Obj6 - Shouldn't get here");
- end if;
- end;
-
- exception
- when Constraint_Error => -- Exception expected.
- null;
- when others =>
- Report.Failed ("Obj6 - others exception raised");
- end;
-
- exception
- when Constraint_Error =>
- Report.Failed ("Rec_Of_Rec_Of_MyArr - Constraint_Error raised");
- when others =>
- Report.Failed ("Rec_Of_Rec_Of_MyArr - others exception raised");
- end;
-
- ---------------------------------------------------------
- begin
- declare
- type New_Rec is
- new Rec_Of_MyArr_01(1); -- No Constraint_Error raised.
-
- begin
- declare
- Obj7 : New_Rec; -- Constraint_Error raised.
- begin
- Report.Failed ("Obj7 - Constraint_Error should be raised");
- if Obj7 /= (1, (1, 1)) then
- Report.Comment ("Obj7 - Shouldn't get here");
- end if;
- end;
-
- exception
- when Constraint_Error => -- Exception expected.
- null;
- when others =>
- Report.Failed ("Obj7 - others exception raised");
- end;
-
- exception
- when Constraint_Error =>
- Report.Failed ("New_Rec - Constraint_Error raised");
- when others =>
- Report.Failed ("New_Rec - others exception raised");
- end;
-
- ---------------------------------------------------------
- begin
- declare
- type Acc_Rec is
- access Rec_Of_Rec_02 (Report.Ident_Int(0));
- -- No Constraint_Error raised.
- begin
- declare
- Obj8 : Acc_Rec; -- No Constraint_Error raised.
-
- begin
- Obj8 := new Rec_Of_Rec_02 (Report.Ident_Int(0));
- -- Constraint_Error raised.
-
- Report.Failed ("Obj8 - Constraint_Error should be raised");
- if Obj8.all /= (D3 => 1,
- C1 => (Disc1 => 1,
- Disc2 => 1,
- Str1 => (others => '*'),
- Str2 => (others => '*'))) then
- Report.Comment ("Obj8 - Shouldn't get here");
- end if;
- end;
-
- exception
- when Constraint_Error => -- Exception expected.
- null;
- when others =>
- Report.Failed ("Obj8 - others exception raised");
- end;
-
- exception
- when Constraint_Error =>
- Report.Failed ("Acc_Rec - Constraint_Error raised");
- when others =>
- Report.Failed ("Acc_Rec - others exception raised");
- end;
-
- ---------------------------------------------------------
- begin
- declare
- type Acc_Rec_MyArr is access
- Rec_Of_MyArr_02; -- No Constraint_Error
- -- raised for either
- Obj9 : Acc_Rec_MyArr; -- declaration.
-
- begin
- Obj9 := new Rec_Of_MyArr_02 (Report.Ident_Int(0));
- -- Constraint_Error raised.
-
- Report.Failed ("Obj9 - Constraint_Error should be raised");
-
- if Obj9.all /= (1, (1, 1)) then
- Report.Comment ("Obj9 - Shouldn't get here");
- end if;
-
- exception
- when Constraint_Error => -- Exception expected.
- null;
- when others =>
- Report.Failed ("Obj9 - others exception raised");
- end;
-
- exception
- when Constraint_Error =>
- Report.Failed ("Acc_Rec_MyArr - Constraint_Error raised");
- when others =>
- Report.Failed ("Acc_Rec_MyArr - others exception raised");
- end;
-
- end;
-
- Report.Result;
-
-exception
- when others =>
- Report.Failed ("Discriminant value checked too soon");
- Report.Result;
-
-end C371002;