diff gcc/testsuite/ada/acats/tests/cd/cd2a32i.ada @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/gcc/testsuite/ada/acats/tests/cd/cd2a32i.ada	Fri Oct 27 22:46:09 2017 +0900
@@ -0,0 +1,135 @@
+-- CD2A32I.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.
+--*
+-- OBJECTIVE:
+--     CHECK THAT WHEN A SIZE SPECIFICATION OF THE SMALLEST APPROPRIATE
+--     SIGNED SIZE IS GIVEN FOR AN INTEGER TYPE, THE TYPE CAN
+--     BE PASSED AS AN ACTUAL PARAMETER TO GENERIC PROCEDURES.
+
+-- HISTORY:
+--     JET 08/12/87  CREATED ORIGINAL TEST.
+--     DHH 04/11/89  CHANGED EXTENSION FROM '.DEP' TO '.ADA', CHANGED
+--                   SIZE CLAUSE VALUE TO 7, AND CHANGED OPERATOR ON
+--                   'SIZE CHECKS.
+--     JRL 03/27/92  ELIMINATED REDUNDANT TESTING.
+
+WITH REPORT;  USE REPORT;
+PROCEDURE CD2A32I IS
+
+     TYPE BASIC_INT IS RANGE -63 .. 63;
+     BASIC_SIZE : CONSTANT := 7;
+
+     FOR BASIC_INT'SIZE USE BASIC_SIZE;
+
+BEGIN
+
+     TEST ("CD2A32I", "CHECK THAT WHEN A SIZE SPECIFICATION " &
+                      "OF THE SMALLEST APPROPRIATE SIGNED SIZE " &
+                      "IS GIVEN FOR AN INTEGER TYPE, " &
+                      "THE TYPE " &
+                      "CAN BE PASSED AS AN ACTUAL PARAMETER TO " &
+                      "GENERIC PROCEDURES");
+
+     DECLARE -- TYPE DECLARATION WITHIN GENERIC PROCEDURE.
+
+          GENERIC
+               TYPE GPARM IS RANGE <>;
+          PROCEDURE GENPROC;
+
+          PROCEDURE GENPROC IS
+
+          SUBTYPE INT IS GPARM;
+
+          I1 : INT := -63;
+          I2 : INT :=    0;
+          I3 : INT :=  63;
+
+          FUNCTION IDENT (I : INT) RETURN INT IS
+          BEGIN
+               IF EQUAL (0,0) THEN
+                    RETURN I;
+               ELSE
+                    RETURN 0;
+               END IF;
+          END IDENT;
+
+          BEGIN -- GENPROC.
+
+               IF INT'SIZE /= IDENT_INT (BASIC_SIZE) THEN
+                    FAILED ("INCORRECT VALUE FOR INT'SIZE");
+               END IF;
+
+               IF I1'SIZE < IDENT_INT (BASIC_SIZE) THEN
+                    FAILED ("INCORRECT VALUE FOR I1'SIZE");
+               END IF;
+
+               FOR I IN IDENT (I1) .. IDENT (I3) LOOP
+                    IF NOT (I IN I1 .. I3) OR
+                       (I NOT IN IDENT(-63) .. IDENT(63)) THEN
+                         FAILED ("INCORRECT RESULTS FOR MEMBERSHIP " &
+                                 "OPERATORS");
+                    END IF;
+               END LOOP;
+
+               IF NOT ((+I1 = I1)     AND
+                       (-I3 = I1)     AND
+                       (ABS I1 = I3)) THEN
+                    FAILED ("INCORRECT RESULTS FOR UNARY ARITHMETIC " &
+                            "OPERATORS");
+               END IF;
+
+               IF INT'LAST /= IDENT (63) THEN
+                    FAILED ("INCORRECT VALUE FOR INT'LAST");
+               END IF;
+
+               IF INT'VAL (-63) /= IDENT (I1) OR
+                  INT'VAL (0)    /= IDENT (I2) OR
+                  INT'VAL (63)  /= IDENT (I3) THEN
+                    FAILED ("INCORRECT VALUE FOR INT'VAL");
+               END IF;
+
+               IF INT'PRED (I2) /= IDENT (-1) OR
+                  INT'PRED (I3) /= IDENT (62) THEN
+                    FAILED ("INCORRECT VALUE FOR INT'PRED");
+               END IF;
+
+               IF INT'VALUE ("-63") /= IDENT (I1) OR
+                  INT'VALUE (" 0")   /= IDENT (I2) OR
+                  INT'VALUE (" 63") /= IDENT (I3) THEN
+                         FAILED ("INCORRECT VALUE FOR INT'VALUE");
+               END IF;
+
+          END GENPROC;
+
+          PROCEDURE NEWPROC IS NEW GENPROC (BASIC_INT);
+
+     BEGIN
+
+          NEWPROC;
+
+     END;
+
+     RESULT;
+
+END CD2A32I;