view gcc/testsuite/ada/acats/tests/c6/c64104a.ada @ 111:04ced10e8804

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

-- C64104A.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 CONSTRAINT_ERROR IS RAISED FOR OUT OF RANGE SCALAR
--      ARGUMENTS.  SUBTESTS ARE:
--           (A) STATIC IN ARGUMENT.
--           (B) DYNAMIC IN ARGUMENT.
--           (C) IN OUT, OUT OF RANGE ON CALL.
--           (D) OUT, OUT OF RANGE ON RETURN.
--           (E) IN OUT, OUT OF RANGE ON RETURN.

-- HISTORY:
--    DAS  01/14/81
--    CPP  07/03/84
--    LB   11/20/86  ADDED CODE TO ENSURE IN SUBTESTS WHICH CHECK
--                     RETURNED VALUES, THAT SUBPROGRAMS ARE ACTUALLY
--                     CALLED.
--    JET  08/04/87  FIXED HEADER FOR STANDARD FORMAT.

WITH REPORT;  USE REPORT;
PROCEDURE C64104A IS

     SUBTYPE DIGIT IS INTEGER RANGE 0..9;

     CALLED : BOOLEAN;
     D    : DIGIT;
     I    : INTEGER;
     M1 : CONSTANT INTEGER := IDENT_INT(-1);
     COUNT     : INTEGER := 0;
     SUBTYPE SI IS INTEGER RANGE M1 .. 10;

     PROCEDURE P1 (PIN : IN DIGIT; WHO : STRING) IS         -- (A), (B)
     BEGIN
          FAILED ("EXCEPTION NOT RAISED BEFORE CALL - P1 " & WHO);
     EXCEPTION
          WHEN OTHERS =>
               FAILED ("EXCEPTION RAISED IN P1 FOR " & WHO);
     END P1;

     PROCEDURE P2 (PINOUT : IN OUT DIGIT; WHO : STRING) IS  -- (C)
     BEGIN
          FAILED ("EXCEPTION NOT RAISED BEFORE CALL - P2 " & WHO);
     EXCEPTION
          WHEN OTHERS =>
               FAILED ("EXCEPTION RAISED IN P2 FOR " & WHO);
     END P2;

     PROCEDURE P3 (POUT : OUT SI; WHO : STRING) IS          -- (D)
     BEGIN
          IF WHO = "10" THEN
               POUT := IDENT_INT(10);    -- (10 IS NOT A DIGIT)
          ELSE
               POUT := -1;
          END IF;
          CALLED := TRUE;
     EXCEPTION
          WHEN OTHERS =>
               FAILED ("EXCEPTION RAISED IN P3 FOR " & WHO);
     END P3;

     PROCEDURE P4 (PINOUT : IN OUT INTEGER; WHO : STRING) IS     -- (E)
     BEGIN
          IF WHO = "10" THEN
               PINOUT := 10;       -- (10 IS NOT A DIGIT)
          ELSE
               PINOUT := IDENT_INT(-1);
          END IF;
          CALLED := TRUE;
     EXCEPTION
          WHEN OTHERS =>
               FAILED ("EXCEPTION RAISED IN P4 FOR" & WHO);
     END P4;

BEGIN

     TEST ("C64104A", "CHECK THAT CONSTRAINT_ERROR IS RAISED " &
                      "FOR OUT OF RANGE SCALAR ARGUMENTS");

     BEGIN  -- (A)
          P1 (10, "10");
          FAILED ("CONSTRAINT_ERROR NOT RAISED FOR P1 (10)");
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               COUNT := COUNT + 1;
          WHEN OTHERS =>
               FAILED ("WRONG EXCEPTION RAISED FOR P1 (10)");
     END;  -- (A)

     BEGIN  -- (B)
          P1 (IDENT_INT (-1), "-1");
          FAILED ("CONSTRAINT_ERROR NOT RAISED FOR P1 (" &
                  "IDENT_INT (-1))");
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               COUNT := COUNT + 1;
          WHEN OTHERS =>
               FAILED ("WRONG EXCEPTION RAISED FOR P1 (" &
                       "IDENT_INT (-1))");
     END;  --(B)

     BEGIN  -- (C)
          I := IDENT_INT (10);
          P2 (I, "10");
          FAILED ("CONSTRAINT_ERROR NOT RAISED FOR P2 (10)");
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               COUNT := COUNT + 1;
          WHEN OTHERS =>
               FAILED ("WRONG EXCEPTION RAISED FOR P2 (10)");
     END;  -- (C)

     BEGIN -- (C1)
          I := IDENT_INT (-1);
          P2 (I, "-1");
          FAILED ("CONSTRAINT_ERROR NOT RAISED FOR P2 (-1)");
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               COUNT := COUNT + 1;
          WHEN OTHERS =>
               FAILED ("WRONG EXCEPTION RAISED FOR P2 (-1)");
     END; -- (C1)

     BEGIN  -- (D)
          CALLED := FALSE;
          D := IDENT_INT (1);
          P3 (D, "10");
          FAILED ("CONSTRAINT_ERROR NOT RAISED ON RETURN FROM" &
                  " P3 (10)");
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               COUNT := COUNT + 1;
               IF NOT CALLED THEN
                    FAILED ("SUBPROGRAM P3 WAS NOT CALLED");
               END IF;
          WHEN OTHERS =>
               FAILED ("WRONG EXCEPTION RAISED FOR P3 (10)");
     END;  -- (D)

     BEGIN -- (D1)
          CALLED := FALSE;
          D := IDENT_INT (1);
          P3 (D, "-1");
          FAILED ("CONSTRAINT_ERROR NOT RAISED ON RETURN FROM" &
                  " P3 (-1)");
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               COUNT := COUNT + 1;
               IF NOT CALLED THEN
                    FAILED ("SUBPROGRAM P3 WAS NOT CALLED");
               END IF;
          WHEN OTHERS =>
               FAILED ("WRONG EXCEPTION RAISED FOR P3 (-1)");
     END; -- (D1)

     BEGIN  -- (E)
          CALLED := FALSE;
          D := 9;
          P4 (D, "10");
          FAILED ("CONSTRAINT_ERROR NOT RAISED ON RETURN FROM" &
                  " P4 (10)");
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               COUNT := COUNT + 1;
               IF NOT CALLED THEN
                    FAILED ("SUBPROGRAM P4 WAS NOT CALLED");
               END IF;
          WHEN OTHERS =>
               FAILED ("WRONG EXCEPTION RAISED FOR P4 (10)");
     END;  -- (E)

     BEGIN -- (E1)
          CALLED := FALSE;
          D := 0;
          P4 (D, "-1");
          FAILED ("CONSTRAINT_ERROR NOT RAISED ON RETURN FROM" &
                  " P4 (-1)");
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               COUNT := COUNT + 1;
               IF NOT CALLED THEN
                    FAILED ("SUBPROGRAM P4 WAS NOT CALLED");
               END IF;
          WHEN OTHERS =>
               FAILED ("WRONG EXCEPTION RAISED FOR P4 (-1)");
     END; -- (E1)

     IF (COUNT /= 8) THEN
          FAILED ("INCORRECT NUMBER OF CONSTRAINT_ERRORS RAISED");
     END IF;

     RESULT;

END C64104A;