aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.9/gcc/testsuite/ada/acats/tests/c3/c37006a.ada
diff options
context:
space:
mode:
Diffstat (limited to 'gcc-4.9/gcc/testsuite/ada/acats/tests/c3/c37006a.ada')
-rw-r--r--gcc-4.9/gcc/testsuite/ada/acats/tests/c3/c37006a.ada272
1 files changed, 272 insertions, 0 deletions
diff --git a/gcc-4.9/gcc/testsuite/ada/acats/tests/c3/c37006a.ada b/gcc-4.9/gcc/testsuite/ada/acats/tests/c3/c37006a.ada
new file mode 100644
index 000000000..ac926d1f4
--- /dev/null
+++ b/gcc-4.9/gcc/testsuite/ada/acats/tests/c3/c37006a.ada
@@ -0,0 +1,272 @@
+-- C37006A.ADA
+
+-- 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.
+--*
+-- FOR A COMPONENT OF A RECORD, ACCESS, OR PRIVATE TYPE, OR FOR A
+-- LIMITED PRIVATE COMPONENT, CHECK THAT A NON-STATIC EXPRESSION CAN
+-- BE USED IN A DISCRIMINANT CONSTRAINT OR (EXCEPTING LIMITED PRIVATE
+-- COMPONENTS) IN SPECIFYING A DEFAULT INITIAL VALUE.
+
+-- R.WILLIAMS 8/28/86
+
+WITH REPORT; USE REPORT;
+PROCEDURE C37006A IS
+
+ SUBTYPE INT IS INTEGER RANGE 0 .. 100;
+
+ TYPE ARR IS ARRAY (INT RANGE <>) OF INTEGER;
+
+ TYPE REC1 (D1, D2 : INT) IS
+ RECORD
+ A : ARR (D1 .. D2);
+ END RECORD;
+
+ TYPE REC1_NAME IS ACCESS REC1;
+
+ PROCEDURE CHECK (AR : ARR; STR : STRING) IS
+ BEGIN
+ IF AR'FIRST /= 1 OR AR'LAST /= 2 THEN
+ FAILED ( "INCORRECT BOUNDS FOR R.COMP.A IN COMPONENT " &
+ "OF " & STR & " TYPE");
+ ELSIF AR /= (3, 4) THEN
+ FAILED ( "INITIALIZATION OF R.COMP.A IN COMPONENT OF " &
+ STR & " TYPE FAILED" );
+ END IF;
+ END CHECK;
+
+ PACKAGE PACK IS
+ TYPE PRIV (D1, D2 : INT) IS PRIVATE;
+ TYPE LIM (D1, D2 : INT) IS LIMITED PRIVATE;
+ FUNCTION PRIV_FUN (PARM1, PARM2 : INTEGER) RETURN PRIV;
+ PROCEDURE PRIV_CHECK (R : PRIV);
+ PROCEDURE LIM_CHECK (R : LIM);
+
+ PRIVATE
+ TYPE PRIV (D1, D2 : INT) IS
+ RECORD
+ A : ARR (D1 .. D2);
+ END RECORD;
+
+ TYPE LIM (D1, D2 : INT) IS
+ RECORD
+ A : ARR (D1 .. D2);
+ END RECORD;
+ END PACK;
+
+ PACKAGE BODY PACK IS
+
+ FUNCTION PRIV_FUN (PARM1, PARM2 : INTEGER) RETURN PRIV IS
+ BEGIN
+ RETURN (IDENT_INT (1), IDENT_INT (2),
+ ARR'(1 => 3, 2 => 4));
+ END PRIV_FUN;
+
+ PROCEDURE PRIV_CHECK (R : PRIV) IS
+ BEGIN
+ CHECK (R.A, "PRIVATE TYPE" );
+ END PRIV_CHECK;
+
+ PROCEDURE LIM_CHECK (R : LIM) IS
+ BEGIN
+ IF R.A'FIRST /= 1 OR R.A'LAST /= 2 THEN
+ FAILED ( "INCORRECT BOUNDS FOR R.COMP.A IN " &
+ "COMPONENT OF LIMITED PRIVATE TYPE");
+ END IF;
+ END LIM_CHECK;
+ END PACK;
+
+ USE PACK;
+
+BEGIN
+
+ TEST ( "C37006A", "FOR A COMPONENT OF A RECORD, ACCESS, " &
+ "OR PRIVATE TYPE, OR FOR A LIMITED PRIVATE " &
+ "COMPONENT, CHECK THAT A NON-STATIC " &
+ "EXPRESSION CAN BE USED IN A DISCRIMINANT " &
+ "CONSTRAINT OR (EXCEPTING LIMITED PRIVATE " &
+ "COMPONENTS) IN SPECIFYING A DEFAULT " &
+ "INITIAL VALUE" );
+
+ BEGIN
+ DECLARE
+
+ TYPE REC2 IS
+ RECORD
+ COMP : REC1 (IDENT_INT (1), IDENT_INT (2)) :=
+ (IDENT_INT (1), IDENT_INT (2),
+ ARR'(1 => 3, 2 => 4));
+ END RECORD;
+
+ R : REC2;
+
+ BEGIN
+ IF R.COMP.D1 = 1 AND R.COMP.D2 = 2 THEN
+ CHECK (R.COMP.A, "RECORD");
+ ELSE
+ FAILED ( "INCORRECT VALUE FOR DISCRIMINANTS " &
+ "OF RECORD TYPE COMPONENT" );
+ END IF;
+
+ EXCEPTION
+ WHEN CONSTRAINT_ERROR =>
+ FAILED ( "CONSTRAINT_ERROR RAISED IN STATEMENT " &
+ "SEQUENCE FOLLOWING DECLARATION OF " &
+ "RECORD TYPE COMPONENT" );
+ WHEN OTHERS =>
+ FAILED ( "OTHER EXCEPTION RAISED IN STATEMENT " &
+ "SEQUENCE FOLLOWING DECLARATION OF " &
+ "RECORD TYPE COMPONENT" );
+ END;
+
+ EXCEPTION
+ WHEN CONSTRAINT_ERROR =>
+ FAILED ( "CONSTRAINT_ERROR RAISED BY DECLARATION " &
+ "OF RECORD TYPE COMPONENT" );
+ WHEN OTHERS =>
+ FAILED ( "OTHER EXCEPTION RAISED BY DECLARATION " &
+ "OF RECORD TYPE COMPONENT" );
+ END;
+
+ BEGIN
+ DECLARE
+
+ TYPE REC2 IS
+ RECORD
+ COMP : REC1_NAME (IDENT_INT (1),
+ IDENT_INT (2)) :=
+ NEW REC1'(IDENT_INT (1),
+ IDENT_INT (2),
+ ARR'(1 => 3, 2 => 4));
+ END RECORD;
+
+ R : REC2;
+
+ BEGIN
+ IF R.COMP.D1 = 1 AND R.COMP.D2 = 2 THEN
+ CHECK (R.COMP.A, "ACCESS");
+ ELSE
+ FAILED ( "INCORRECT VALUE FOR DISCRIMINANTS " &
+ "OF ACCESS TYPE COMPONENT" );
+ END IF;
+
+ EXCEPTION
+ WHEN CONSTRAINT_ERROR =>
+ FAILED ( "CONSTRAINT_ERROR RAISED IN STATEMENT " &
+ "SEQUENCE FOLLOWING DECLARATION OF " &
+ "ACCESS TYPE COMPONENT" );
+ WHEN OTHERS =>
+ FAILED ( "OTHER EXCEPTION RAISED IN STATEMENT " &
+ "SEQUENCE FOLLOWING DECLARATION OF " &
+ "ACCESS TYPE COMPONENT" );
+ END;
+
+ EXCEPTION
+ WHEN CONSTRAINT_ERROR =>
+ FAILED ( "CONSTRAINT_ERROR RAISED BY DECLARATION " &
+ "OF ACCESS TYPE COMPONENT" );
+ WHEN OTHERS =>
+ FAILED ( "OTHER EXCEPTION RAISED BY DECLARATION " &
+ "OF ACCESS TYPE COMPONENT" );
+ END;
+
+ BEGIN
+ DECLARE
+
+ TYPE REC2 IS
+ RECORD
+ COMP : PRIV (IDENT_INT (1), IDENT_INT (2)) :=
+ PRIV_FUN (IDENT_INT (1),
+ IDENT_INT (2));
+ END RECORD;
+
+ R : REC2;
+
+ BEGIN
+ IF R.COMP.D1 = 1 AND R.COMP.D2 = 2 THEN
+ PRIV_CHECK (R.COMP);
+ ELSE
+ FAILED ( "INCORRECT VALUE FOR DISCRIMINANTS " &
+ "OF PRIVATE TYPE COMPONENT" );
+ END IF;
+
+ EXCEPTION
+ WHEN CONSTRAINT_ERROR =>
+ FAILED ( "CONSTRAINT_ERROR RAISED IN STATEMENT " &
+ "SEQUENCE FOLLOWING DECLARATION OF " &
+ "PRIVATE TYPE COMPONENT" );
+ WHEN OTHERS =>
+ FAILED ( "OTHER EXCEPTION RAISED IN STATEMENT " &
+ "SEQUENCE FOLLOWING DECLARATION OF " &
+ "PRIVATE TYPE COMPONENT" );
+ END;
+
+ EXCEPTION
+ WHEN CONSTRAINT_ERROR =>
+ FAILED ( "CONSTRAINT_ERROR RAISED BY DECLARATION " &
+ "OF PRIVATE TYPE COMPONENT" );
+ WHEN OTHERS =>
+ FAILED ( "OTHER EXCEPTION RAISED BY DECLARATION " &
+ "OF PRIVATE TYPE COMPONENT" );
+ END;
+
+ BEGIN
+ DECLARE
+
+ TYPE REC2 IS
+ RECORD
+ COMP : LIM (IDENT_INT (1), IDENT_INT (2));
+ END RECORD;
+
+ R : REC2;
+
+ BEGIN
+ IF R.COMP.D1 = 1 AND R.COMP.D2 = 2 THEN
+ LIM_CHECK (R.COMP);
+ ELSE
+ FAILED ( "INCORRECT VALUE FOR DISCRIMINANTS " &
+ "OF LIM PRIV TYPE COMPONENT" );
+ END IF;
+
+ EXCEPTION
+ WHEN CONSTRAINT_ERROR =>
+ FAILED ( "CONSTRAINT_ERROR RAISED IN STATEMENT " &
+ "SEQUENCE FOLLOWING DECLARATION OF " &
+ " LIM PRIV TYPE COMPONENT" );
+ WHEN OTHERS =>
+ FAILED ( "OTHER EXCEPTION RAISED IN STATEMENT " &
+ "SEQUENCE FOLLOWING DECLARATION OF " &
+ " LIM PRIV TYPE COMPONENT" );
+ END;
+
+ EXCEPTION
+ WHEN CONSTRAINT_ERROR =>
+ FAILED ( "CONSTRAINT_ERROR RAISED BY DECLARATION " &
+ "OF LIM PRIV TYPE COMPONENT" );
+ WHEN OTHERS =>
+ FAILED ( "OTHER EXCEPTION RAISED BY DECLARATION " &
+ "OF LIM PRIV TYPE COMPONENT" );
+ END;
+
+ RESULT;
+
+END C37006A;