view gcc/testsuite/ada/acats/tests/c5/c55b06a.ada @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
line wrap: on
line source

-- C55B06A.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.
--*
-- CHECK THAT LOOPS MAY BE SPECIFIED FOR BOOLEAN, INTEGER,
-- CHARACTER, ENUMERATION, AND DERIVED TYPES, INCLUDING
-- TYPES DERIVED FROM DERIVED TYPES. DERIVED BOOLEAN IS NOT
-- TESTED IN THIS TEST.

-- DAT 3/26/81
-- JBG 9/29/82
-- SPS 3/11/83
-- JBG 10/5/83
-- PWN 01/31/95  REMOVED INCONSISTENCIES WITH ADA 9X.

WITH REPORT; USE REPORT;

PROCEDURE C55B06A IS

     TYPE ENUM IS ('A', 'B', 'D', 'C', Z, X, D, A, C);

     TYPE D1 IS NEW CHARACTER RANGE 'A' .. 'Z';
     TYPE D2 IS NEW INTEGER;
     TYPE D3 IS NEW ENUM;
     TYPE D4 IS NEW D1;
     TYPE D5 IS NEW D2;
     TYPE D6 IS NEW D3;

     ONE : INTEGER := IDENT_INT(1);
     COUNT : INTEGER := 0;
     OLDCOUNT : INTEGER := 0;

     PROCEDURE Q IS
     BEGIN
          COUNT := COUNT + ONE;
     END Q;

BEGIN
     TEST ("C55B06A", "TEST LOOPS FOR ALL DISCRETE TYPES");

     FOR I IN BOOLEAN LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(2) /= COUNT THEN
          FAILED ("LOOP 1");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN FALSE .. TRUE LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(2) /= COUNT THEN
          FAILED ("LOOP 2");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN BOOLEAN RANGE FALSE .. TRUE LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(2) /= COUNT THEN
          FAILED ("LOOP 3");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN INTEGER LOOP
          Q;
          EXIT WHEN I = INTEGER'FIRST + 2;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(3) /= COUNT THEN
          FAILED ("LOOP 4");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN 3 .. IDENT_INT (5) LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(3) /= COUNT THEN
          FAILED ("LOOP 5");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN INTEGER RANGE -2 .. -1 LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(2) /= COUNT THEN
          FAILED ("LOOP 6");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN INTEGER RANGE INTEGER'FIRST .. INTEGER'FIRST + 1 LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(2) /= COUNT THEN
          FAILED ("LOOP 7");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN 'A' .. CHARACTER'('Z') LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(26) /= COUNT THEN
          FAILED ("LOOP 9");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN CHARACTER RANGE 'A' .. 'D' LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(4) /= COUNT THEN
          FAILED ("LOOP 10");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN ENUM LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(9) /= COUNT THEN
          FAILED ("LOOP 11");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN ENUM RANGE D .. C LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(3) /= COUNT THEN
          FAILED ("LOOP 12");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN 'A' .. ENUM'(Z) LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(5) /= COUNT THEN
          FAILED ("LOOP 13");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN D1 LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(26) /= COUNT THEN
          FAILED ("LOOP 14");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN D1 RANGE 'A' .. 'Z' LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(26) /= COUNT THEN
          FAILED ("LOOP 15");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN D1'('A') .. 'D' LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(4) /= COUNT THEN
          FAILED ("LOOP 16");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN D2 LOOP
          Q;
          IF I > D2'FIRST + 3 THEN
               EXIT;
          END IF;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(5) /= COUNT THEN
          FAILED ("LOOP 17");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN D2 RANGE -100 .. -99 LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(2) /= COUNT THEN
          FAILED ("LOOP 18");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN D2'(1) .. 2 LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(2) /= COUNT THEN
          FAILED ("LOOP 19");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN D3 LOOP
          IF I IN 'A' .. 'C' THEN
               Q;        -- 4
          ELSE
               Q; Q;     -- 10
          END IF;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(14) /= COUNT THEN
          FAILED ("LOOP 20");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN D3 RANGE 'A' .. Z LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(5) /= COUNT THEN
          FAILED ("LOOP 21");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN 'A' .. D3'(Z) LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(5) /= COUNT THEN
          FAILED ("LOOP 22");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN D4 LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(26) /= COUNT THEN
          FAILED ("LOOP 23");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN D4'('A') .. 'Z' LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(26) /= COUNT THEN
          FAILED ("LOOP 24");
     END IF;
     OLDCOUNT := COUNT;

     FOR I IN D4 RANGE 'B' .. 'D' LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(3) /= COUNT THEN
          FAILED ("LOOP 25");
     END IF;
     OLDCOUNT := COUNT;

     FOR J IN D5 LOOP
          Q;        -- 4
          EXIT WHEN J = D5(INTEGER'FIRST) + 3;
          Q;        -- 3
     END LOOP;
     IF OLDCOUNT + IDENT_INT(7) /= COUNT THEN
          FAILED ("LOOP 26");
     END IF;
     OLDCOUNT := COUNT;

     FOR J IN D5 RANGE -2 .. -1 LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(2) /= COUNT THEN
          FAILED ("LOOP 27");
     END IF;
     OLDCOUNT := COUNT;

     FOR  J IN D5'(-10) .. D5'(-6) LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(5) /= COUNT THEN
          FAILED ("LOOP 28");
     END IF;
     OLDCOUNT := COUNT;

     FOR J IN D6 LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(9) /= COUNT THEN
          FAILED ("LOOP 29");
     END IF;
     OLDCOUNT := COUNT;

     FOR J IN D6 RANGE Z .. A LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(4) /= COUNT THEN
          FAILED ("LOOP 30");
     END IF;
     OLDCOUNT := COUNT;

     FOR J IN D6'('D') .. D LOOP
          Q;
     END LOOP;
     IF OLDCOUNT + IDENT_INT(5) /= COUNT THEN
          FAILED ("LOOP 31");
     END IF;
     OLDCOUNT := COUNT;


     RESULT;
END C55B06A;