view gcc/testsuite/ada/acats/tests/c4/c47009b.ada @ 111:04ced10e8804

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

-- C47009B.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:
--     WHEN THE TYPE MARK IN A QUALIFIED EXPRESSION DENOTES AN ACCESS
--     TYPE, CHECK THAT CONSTRAINT_ERROR IS NOT RAISED WHEN THE VALUE
--     OF THE OPERAND IS NULL.

-- HISTORY:
--     RJW 07/23/86  CREATED ORIGINAL TEST.
--     BCB 08/18/87  CHANGED HEADER TO STANDARD HEADER FORMAT.  CHANGED
--                   CONSTRAINTS OF B SUBTYPES TO VALUES WHICH ARE
--                   CLOSER TO THE VALUES OF THE A SUBTYPES.  INDENTED
--                   THE EXCEPTION STATEMENTS IN SUBTEST 11.

WITH REPORT; USE REPORT;
PROCEDURE C47009B IS

BEGIN

     TEST( "C47009B", "WHEN THE TYPE MARK IN A QUALIFIED " &
                      "EXPRESSION DENOTES AN ACCESS TYPE, " &
                      "CHECK THAT CONSTRAINT_ERROR IS NOT " &
                      "RAISED WHEN THE VALUE OF THE OPERAND IS NULL" );

     DECLARE

          TYPE ACC1 IS ACCESS BOOLEAN;
          A : ACC1;

     BEGIN
          A := ACC1'(NULL);
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               FAILED ( "CONSTRAINT_ERROR RAISED FOR TYPE ACC1" );
          WHEN OTHERS =>
               FAILED ( "OTHER EXCEPTION RAISED FOR TYPE ACC1" );
     END;

     DECLARE

          TYPE ACC2 IS ACCESS INTEGER;
          A : ACC2;

     BEGIN
          A := ACC2'(NULL);
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               FAILED ( "CONSTRAINT_ERROR RAISED FOR TYPE ACC2" );
          WHEN OTHERS =>
               FAILED ( "OTHER EXCEPTION RAISED FOR TYPE ACC2" );
     END;

     DECLARE

          TYPE CHAR IS ('A', 'B');
          TYPE ACC3 IS ACCESS CHAR;
          A : ACC3;

     BEGIN
          A := ACC3'(NULL);
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               FAILED ( "CONSTRAINT_ERROR RAISED FOR TYPE ACC3" );
          WHEN OTHERS =>
               FAILED ( "OTHER EXCEPTION RAISED FOR TYPE ACC3" );
     END;

     DECLARE

          TYPE FLOAT1 IS DIGITS 5 RANGE -1.0 .. 1.0;
          TYPE ACC4 IS ACCESS FLOAT1;
          A : ACC4;

     BEGIN
          A := ACC4'(NULL);
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               FAILED ( "CONSTRAINT_ERROR RAISED FOR TYPE ACC4" );
          WHEN OTHERS =>
               FAILED ( "OTHER EXCEPTION RAISED FOR TYPE ACC4" );
     END;

     DECLARE

          TYPE FIXED IS DELTA 0.5 RANGE -1.0 .. 1.0;
          TYPE ACC5 IS ACCESS FIXED;
          A : ACC5;

     BEGIN
          A := ACC5'(NULL);
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               FAILED ( "CONSTRAINT_ERROR RAISED FOR TYPE ACC5" );
          WHEN OTHERS =>
               FAILED ( "OTHER EXCEPTION RAISED FOR TYPE ACC5" );
     END;

     DECLARE

          TYPE ARR IS ARRAY (NATURAL RANGE <>) OF INTEGER;
          TYPE ACC6 IS ACCESS ARR;
          SUBTYPE ACC6A IS ACC6 (IDENT_INT (1) .. IDENT_INT (5));
          SUBTYPE ACC6B IS ACC6 (IDENT_INT (2) .. IDENT_INT (10));
          A : ACC6A;
          B : ACC6B;

     BEGIN
          A := ACC6A'(B);
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               FAILED ( "CONSTRAINT_ERROR RAISED FOR SUBTYPES OF " &
                        "TYPE ACC6" );
          WHEN OTHERS =>
               FAILED ( "OTHER EXCEPTION RAISED FOR SUBTYPES OF " &
                        "TYPE ACC6" );
     END;

     DECLARE

          TYPE ARR IS ARRAY (NATURAL RANGE <>, NATURAL RANGE <>)
               OF INTEGER;
          TYPE ACC7 IS ACCESS ARR;
          SUBTYPE ACC7A IS ACC7 (IDENT_INT (1) .. IDENT_INT (5),
                                 IDENT_INT (1) .. IDENT_INT (1));
          SUBTYPE ACC7B IS ACC7 (IDENT_INT (1) .. IDENT_INT (15),
                                 IDENT_INT (1) .. IDENT_INT (10));
          A : ACC7A;
          B : ACC7B;

     BEGIN
          A := ACC7A'(B);
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               FAILED ( "CONSTRAINT_ERROR RAISED FOR SUBTYPES OF " &
                        "TYPE ACC7" );
          WHEN OTHERS =>
               FAILED ( "OTHER EXCEPTION RAISED FOR SUBTYPES OF " &
                        "TYPE ACC7" );
     END;

     DECLARE

          TYPE REC (D : INTEGER) IS
               RECORD
                    NULL;
               END RECORD;

          TYPE ACC8 IS ACCESS REC;
          SUBTYPE ACC8A IS ACC8 (IDENT_INT (5));
          SUBTYPE ACC8B IS ACC8 (IDENT_INT (6));
          A : ACC8A;
          B : ACC8B;

     BEGIN
          A := ACC8A'(B);
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               FAILED ( "CONSTRAINT_ERROR RAISED FOR SUBTYPES OF " &
                        "TYPE ACC8" );
          WHEN OTHERS =>
               FAILED ( "OTHER EXCEPTION RAISED FOR SUBTYPES OF " &
                        "TYPE ACC8" );
     END;

     DECLARE

          TYPE REC (D1,D2 : INTEGER) IS
               RECORD
                    NULL;
               END RECORD;

          TYPE ACC9 IS ACCESS REC;
          SUBTYPE ACC9A IS ACC9 (IDENT_INT (4), IDENT_INT (5));
          SUBTYPE ACC9B IS ACC9 (IDENT_INT (5), IDENT_INT (4));
          A : ACC9A;
          B : ACC9B;

     BEGIN
          A := ACC9A'(B);
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               FAILED ( "CONSTRAINT_ERROR RAISED FOR SUBTYPES OF " &
                        "TYPE ACC9" );
          WHEN OTHERS =>
               FAILED ( "OTHER EXCEPTION RAISED FOR SUBTYPES OF " &
                        "TYPE ACC9" );
     END;

     DECLARE

          PACKAGE PKG IS
               TYPE REC (D : INTEGER) IS PRIVATE;

          PRIVATE
               TYPE REC (D : INTEGER) IS
                    RECORD
                         NULL;
                    END RECORD;

          END PKG;

          USE PKG;

          TYPE ACC10 IS ACCESS REC;
          SUBTYPE ACC10A IS ACC10 (IDENT_INT (10));
          SUBTYPE ACC10B IS ACC10 (IDENT_INT (9));
          A : ACC10A;
          B : ACC10B;

     BEGIN
          A := ACC10A'(B);
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
               FAILED ( "CONSTRAINT_ERROR RAISED FOR SUBTYPES OF " &
                        "TYPE ACC10" );
          WHEN OTHERS =>
               FAILED ( "OTHER EXCEPTION RAISED FOR SUBTYPES OF " &
                        "TYPE ACC10" );
     END;

     DECLARE

          PACKAGE PKG1 IS
               TYPE REC (D : INTEGER) IS LIMITED PRIVATE;

          PRIVATE
               TYPE REC (D : INTEGER) IS
                    RECORD
                         NULL;
                    END RECORD;
          END PKG1;

          PACKAGE PKG2 IS END PKG2;

          PACKAGE BODY PKG2 IS
               USE PKG1;

               TYPE ACC11 IS ACCESS REC;
               SUBTYPE ACC11A IS ACC11 (IDENT_INT (11));
               SUBTYPE ACC11B IS ACC11 (IDENT_INT (12));
               A : ACC11A;
               B : ACC11B;

          BEGIN
               A := ACC11A'(B);
          EXCEPTION
               WHEN CONSTRAINT_ERROR =>
                    FAILED ( "CONSTRAINT_ERROR RAISED FOR SUBTYPES OF" &
                             " TYPE ACC11" );
               WHEN OTHERS =>
                    FAILED ( "OTHER EXCEPTION RAISED FOR SUBTYPES OF " &
                             "TYPE ACC11" );
          END PKG2;

     BEGIN
          NULL;
     END;

     RESULT;
END C47009B;