view gcc/testsuite/ada/acats/tests/ce/ce2401b.ada @ 111:04ced10e8804

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

-- CE2401B.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 READ (WITH AND WITHOUT PARAMETER FROM), WRITE (WITH
--     AND WITHOUT PARAMETER TO), SET_INDEX, INDEX, SIZE, AND
--     END_OF_FILE FOR DIRECT FILES WITH ELEMENT_TYPES BOOLEAN,
--     ACCESS, AND ENUMERATED.

-- APPLICABILITY CRITERIA:
--     THIS TEST IS ONLY APPLICABLE TO IMPLEMENTATIONS WHICH SUPPORT
--     DIRECT FILES.

-- HISTORY:
--     ABW 08/18/82
--     SPS 09/15/82
--     SPS 11/09/82
--     JBG 02/22/84  CHANGE TO .ADA TEST.
--     EG  05/16/85
--     TBN 11/04/86  REVISED TEST TO OUTPUT A NON_APPLICABLE
--                   RESULT WHEN FILES ARE NOT SUPPORTED.
--     DWC 08/07/87  ISOLATED EXCEPTIONS.

WITH REPORT; USE REPORT;
WITH DIRECT_IO;

PROCEDURE CE2401B IS
     END_SUBTEST : EXCEPTION;
BEGIN

     TEST ("CE2401B", "CHECK READ, WRITE, SET_INDEX " &
                      "INDEX, SIZE, AND END_OF_FILE FOR " &
                      "DIRECT FILES FOR BOOLEAN, ACCESS " &
                      "AND ENUMERATION TYPES");
     DECLARE
          PACKAGE DIR_BOOL IS NEW DIRECT_IO (BOOLEAN);
          USE DIR_BOOL;
          FILE_BOOL : FILE_TYPE;
     BEGIN
          BEGIN
               CREATE (FILE_BOOL, INOUT_FILE, LEGAL_FILE_NAME);
          EXCEPTION
               WHEN USE_ERROR | NAME_ERROR =>
                    NOT_APPLICABLE ("USE_ERROR | NAME_ERROR RAISED " &
                                    "ON CREATE - BOOLEAN");
                    RAISE END_SUBTEST;
               WHEN OTHERS =>
                    FAILED ("UNEXPECTED ERROR RAISED ON " &
                            "CREATE - BOOLEAN");
                    RAISE END_SUBTEST;
          END;

          DECLARE
               BOOL : BOOLEAN := IDENT_BOOL (TRUE);
               ITEM_BOOL : BOOLEAN;
               ONE_BOOL : POSITIVE_COUNT := 1;
               TWO_BOOL : POSITIVE_COUNT := 2;
          BEGIN
               BEGIN
                    WRITE (FILE_BOOL,BOOL);
               EXCEPTION
                    WHEN OTHERS =>
                         FAILED ("EXCEPTION RAISED ON WRITE FOR " &
                                 "BOOLEAN - 1");
               END;

               BEGIN
                    WRITE (FILE_BOOL,BOOL,TWO_BOOL);
               EXCEPTION
                    WHEN OTHERS =>
                         FAILED ("EXCEPTION RAISED ON WRITE FOR " &
                                 "BOOLEAN - 2");
               END;

               BEGIN
                    IF SIZE (FILE_BOOL) /= TWO_BOOL THEN
                         FAILED ("SIZE FOR TYPE BOOLEAN");
                    END IF;
                    IF NOT END_OF_FILE (FILE_BOOL) THEN
                         FAILED ("WRONG END_OF_FILE VALUE FOR " &
                                 "BOOLEAN");
                    END IF;
                    SET_INDEX (FILE_BOOL,ONE_BOOL);
                    IF INDEX (FILE_BOOL) /= ONE_BOOL THEN
                         FAILED ("WRONG INDEX VALUE FOR TYPE BOOLEAN");
                    END IF;
               END;

               CLOSE (FILE_BOOL);

               BEGIN
                    OPEN (FILE_BOOL, IN_FILE, LEGAL_FILE_NAME);
               EXCEPTION
                    WHEN USE_ERROR =>
                         NOT_APPLICABLE ("OPEN FOR IN_FILE MODE " &
                                         "NOT SUPPORTED - 1");
                         RAISE END_SUBTEST;
               END;

               BEGIN
                    READ (FILE_BOOL,ITEM_BOOL);
                    IF ITEM_BOOL /= BOOL THEN
                         FAILED ("INCORRECT BOOLEAN VALUE READ - 1");
                    END IF;
               EXCEPTION
                    WHEN OTHERS =>
                         FAILED ("READ WITHOUT FROM FOR " &
                                 "TYPE BOOLEAN");
               END;

               BEGIN
                    READ (FILE_BOOL,ITEM_BOOL,ONE_BOOL);
                    IF ITEM_BOOL /= BOOL THEN
                         FAILED ("INCORRECT BOOLEAN VALUE READ - 2");
                    END IF;
               EXCEPTION
                    WHEN OTHERS =>
                         FAILED ("READ WITH FROM FOR BOOLEAN");
               END;
          END;

          BEGIN
               DELETE (FILE_BOOL);
          EXCEPTION
               WHEN USE_ERROR =>
                    NULL;
          END;

     EXCEPTION
          WHEN END_SUBTEST =>
               NULL;
     END;

     DECLARE
          TYPE ENUMERATED IS (ONE,TWO,THREE);
          PACKAGE DIR_ENUM IS NEW DIRECT_IO (ENUMERATED);
          USE DIR_ENUM;
          FILE_ENUM : FILE_TYPE;
     BEGIN
          BEGIN
               CREATE (FILE_ENUM, INOUT_FILE, LEGAL_FILE_NAME(2));
          EXCEPTION
               WHEN USE_ERROR | NAME_ERROR =>
                    NOT_APPLICABLE ("USE_ERROR | NAME_ERROR RAISED " &
                                    "ON CREATE - ENUMERATED");
                    RAISE END_SUBTEST;
               WHEN OTHERS =>
                    FAILED ("UNEXPECTED ERROR RAISED ON " &
                            "CREATE - ENUMERATED");
                    RAISE END_SUBTEST;
          END;

          DECLARE
               ENUM : ENUMERATED := (THREE);
               ITEM_ENUM : ENUMERATED;
               ONE_ENUM : POSITIVE_COUNT := 1;
               TWO_ENUM : POSITIVE_COUNT := 2;
          BEGIN
               BEGIN
                    WRITE (FILE_ENUM,ENUM);
               EXCEPTION
                    WHEN OTHERS =>
                         FAILED ("EXCEPTION RAISED ON WRITE FOR " &
                                 "ENUMERATED - 1");
               END;

               BEGIN
                    WRITE (FILE_ENUM,ENUM,TWO_ENUM);
               EXCEPTION
                    WHEN OTHERS =>
                         FAILED ("EXCEPTION RAISED ON WRITE FOR " &
                                 "ENUMERATED - 2");
               END;

               BEGIN
                    IF SIZE (FILE_ENUM) /= TWO_ENUM THEN
                         FAILED ("SIZE FOR TYPE ENUMERATED");
                    END IF;
                    IF NOT END_OF_FILE (FILE_ENUM) THEN
                         FAILED ("WRONG END_OF_FILE VALUE FOR TYPE " &
                                 "ENUMERATED");
                    END IF;
                    SET_INDEX (FILE_ENUM,ONE_ENUM);
                    IF INDEX (FILE_ENUM) /= ONE_ENUM THEN
                         FAILED ("WRONG INDEX VALUE FOR TYPE " &
                                 "ENUMERATED");
                    END IF;
               END;

               CLOSE (FILE_ENUM);

               BEGIN
                    OPEN (FILE_ENUM, IN_FILE, LEGAL_FILE_NAME(2));
               EXCEPTION
                    WHEN USE_ERROR =>
                         NOT_APPLICABLE ("OPEN FOR IN_FILE MODE " &
                                         "NOT SUPPORTED - 2");
                    RAISE END_SUBTEST;
               END;

               BEGIN
                    READ (FILE_ENUM,ITEM_ENUM);
                    IF ITEM_ENUM /= ENUM THEN
                         FAILED ("INCORRECT ENUM VALUE READ - 1");
                    END IF;
               EXCEPTION
                    WHEN OTHERS =>
                         FAILED ("READ WITHOUT FROM FOR ENUMERATED");
               END;

               BEGIN
                    READ (FILE_ENUM,ITEM_ENUM,ONE_ENUM);
                    IF ITEM_ENUM /= ENUM THEN
                         FAILED ("INCORRECT ENUM VALUE READ - 2");
                    END IF;
               EXCEPTION
                    WHEN OTHERS =>
                         FAILED ("READ WITH FROM FOR " &
                                 "TYPE ENUMERATED");
               END;
          END;

          BEGIN
               DELETE (FILE_ENUM);
          EXCEPTION
               WHEN USE_ERROR =>
                    NULL;
          END;

     EXCEPTION
          WHEN END_SUBTEST =>
               NULL;
     END;

     DECLARE
          TYPE ACC_INT IS ACCESS INTEGER;
          PACKAGE DIR_ACC IS NEW DIRECT_IO (ACC_INT);
          USE DIR_ACC;
          FILE_ACC : FILE_TYPE;
     BEGIN
          BEGIN
               CREATE (FILE_ACC, INOUT_FILE, LEGAL_FILE_NAME(3));
          EXCEPTION
               WHEN USE_ERROR | NAME_ERROR =>
                    NOT_APPLICABLE ("USE_ERROR | NAME_ERROR RAISED " &
                                    "ON CREATE - ACCESS");
                    RAISE END_SUBTEST;
          END;

          DECLARE
               ACC : ACC_INT := NEW INTEGER'(33);
               ITEM_ACC : ACC_INT;
               ONE_ACC : POSITIVE_COUNT := 1;
               TWO_ACC : POSITIVE_COUNT := 2;
          BEGIN
               BEGIN
                    WRITE (FILE_ACC,ACC);
               EXCEPTION
                    WHEN OTHERS =>
                         FAILED ("EXCEPTION RAISED ON WRITE FOR " &
                                 "ACCESS - 1");
               END;

               BEGIN
                    WRITE (FILE_ACC,ACC,TWO_ACC);

               EXCEPTION
                    WHEN OTHERS =>
                         FAILED ("EXCEPTION RAISED ON WRITE FOR " &
                                 "ACCESS - 2");
               END;

               BEGIN
                    IF SIZE (FILE_ACC) /= TWO_ACC THEN
                         FAILED ("SIZE FOR TYPE ACCESS");
                    END IF;
                    IF NOT END_OF_FILE (FILE_ACC) THEN
                         FAILED ("WRONG END_OF_FILE VALUE FOR ACCESS");
                    END IF;
                    SET_INDEX (FILE_ACC,ONE_ACC);
                    IF INDEX (FILE_ACC) /= ONE_ACC THEN
                         FAILED ("WRONG INDEX VALUE FOR TYPE ACCESS");
                    END IF;
               END;

               CLOSE (FILE_ACC);

               BEGIN
                    OPEN (FILE_ACC, IN_FILE, LEGAL_FILE_NAME(3));
               EXCEPTION
                    WHEN USE_ERROR =>
                         NOT_APPLICABLE ("OPEN FOR IN_FILE NOT " &
                                         "SUPPORTED - 3");
                         RAISE END_SUBTEST;
               END;

               BEGIN
                    READ (FILE_ACC,ITEM_ACC);
               EXCEPTION
                    WHEN OTHERS =>
                         FAILED ("READ WITHOUT FROM FOR ACCESS");
               END;

               BEGIN
                    READ (FILE_ACC,ITEM_ACC,ONE_ACC);
               EXCEPTION
                    WHEN OTHERS =>
                         FAILED ("READ WITH FROM FOR ACCESS");
               END;
          END;

          BEGIN
               DELETE (FILE_ACC);
          EXCEPTION
               WHEN USE_ERROR =>
                    NULL;
          END;

     EXCEPTION
          WHEN END_SUBTEST =>
               NULL;
     END;

     RESULT;

END CE2401B;