ce2401a.ada

来自「用于进行gcc测试」· ADA 代码 · 共 358 行

ADA
358
字号
-- CE2401A.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 READ (WITH AND WITHOUT PARAMETER FROM), WRITE (WITH--     AND WITHOUT PARAMETER TO), SET_INDEX, INDEX, SIZE AND--     END_OF_FILE ARE SUPPORTED FOR DIRECT FILES WITH ELEMENT_TYPES--     STRING, CHARACTER, AND INTEGER.-- APPLICABILITY CRITERIA:--     THIS TEST IS ONLY APPLICABLE TO IMPLEMENTATIONS WHICH--     SUPPORT DIRECT FILES.-- HISTORY:--     ABW 08/16/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 07/31/87  ISOLATED EXCEPTIONS.WITH REPORT; USE REPORT;WITH DIRECT_IO;PROCEDURE CE2401A IS     END_SUBTEST : EXCEPTION;BEGIN     TEST ("CE2401A" , "CHECK THAT READ, WRITE, SET_INDEX " &                       "INDEX, SIZE AND END_OF_FILE ARE " &                       "SUPPORTED FOR DIRECT FILES");     DECLARE          SUBTYPE STR_TYPE IS STRING (1..12);          PACKAGE DIR_STR IS NEW DIRECT_IO (STR_TYPE);          USE DIR_STR;          FILE_STR : FILE_TYPE;     BEGIN          BEGIN               CREATE (FILE_STR, INOUT_FILE, LEGAL_FILE_NAME);          EXCEPTION               WHEN USE_ERROR | NAME_ERROR =>                    NOT_APPLICABLE ("USE_ERROR | NAME_ERROR RAISED " &                                    "ON CREATE - STRING");                    RAISE END_SUBTEST;               WHEN OTHERS =>                    FAILED ("UNEXPECTED ERROR RAISED ON " &                            "CREATE - STRING");                    RAISE END_SUBTEST;          END;          DECLARE               STR : STR_TYPE := "TEXT OF FILE";               ITEM_STR : STR_TYPE;               ONE_STR : POSITIVE_COUNT := 1;               TWO_STR : POSITIVE_COUNT := 2;          BEGIN               BEGIN                    WRITE (FILE_STR,STR);               EXCEPTION                    WHEN OTHERS =>                         FAILED ("EXCEPTION RAISED ON WRITE FOR " &                                 "STRING - 1");               END;               BEGIN                    WRITE (FILE_STR,STR,TWO_STR);               EXCEPTION                    WHEN OTHERS =>                         FAILED ("EXCEPTION RAISED ON WRITE FOR " &                                 "STRING - 2");               END;               BEGIN                    IF SIZE (FILE_STR) /= TWO_STR THEN                         FAILED ("SIZE FOR TYPE STRING");                    END IF;                    IF NOT END_OF_FILE (FILE_STR) THEN                         FAILED ("WRONG END_OF_FILE VALUE FOR STRING");                    END IF;                    SET_INDEX (FILE_STR,ONE_STR);                    IF INDEX (FILE_STR) /= ONE_STR THEN                         FAILED ("WRONG INDEX VALUE FOR STRING");                    END IF;               END;               CLOSE (FILE_STR);               BEGIN                    OPEN (FILE_STR, 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_STR,ITEM_STR);                    IF ITEM_STR /= STR THEN                         FAILED ("INCORRECT STRING VALUE READ - 1");                    END IF;               EXCEPTION                    WHEN OTHERS =>                         FAILED ("READ WITHOUT FROM FOR STRING");               END;               BEGIN                    READ (FILE_STR,ITEM_STR,ONE_STR);                    IF ITEM_STR /= STR THEN                         FAILED ("INCORRECT STRING VALUE READ - 2");                    END IF;               EXCEPTION                    WHEN OTHERS =>                         FAILED ("READ WITH FROM FOR STRING");               END;          END;          BEGIN               DELETE (FILE_STR);          EXCEPTION               WHEN USE_ERROR =>                    NULL;          END;     EXCEPTION          WHEN END_SUBTEST =>               NULL;     END;     DECLARE          PACKAGE DIR_CHR IS NEW DIRECT_IO (CHARACTER);          USE DIR_CHR;          FILE_CHR : FILE_TYPE;     BEGIN          BEGIN               CREATE (FILE_CHR, INOUT_FILE, LEGAL_FILE_NAME(2));          EXCEPTION               WHEN USE_ERROR | NAME_ERROR =>                    NOT_APPLICABLE ("USE_ERROR | NAME_ERROR RAISED " &                                    "ON CREATE - CHARACTER");                    RAISE END_SUBTEST;               WHEN OTHERS =>                    FAILED ("UNEXPECTED ERROR RAISED ON " &                            "CREATE - CHARACTER");                    RAISE END_SUBTEST;          END;          DECLARE               CHR : CHARACTER := 'C';               ITEM_CHR : CHARACTER;               ONE_CHR : POSITIVE_COUNT := 1;               TWO_CHR : POSITIVE_COUNT := 2;          BEGIN               BEGIN                    WRITE (FILE_CHR,CHR);               EXCEPTION                    WHEN OTHERS =>                         FAILED ("EXCEPTION RAISED ON WRITE FOR " &                                 "CHARACTER - 1");               END;               BEGIN                    WRITE (FILE_CHR,CHR,TWO_CHR);               EXCEPTION                    WHEN OTHERS =>                         FAILED ("EXCEPTION RAISED ON WRITE FOR " &                                 "CHARACTER - 2");               END;               BEGIN                    IF SIZE (FILE_CHR) /= TWO_CHR THEN                         FAILED ("SIZE FOR TYPE CHARACTER");                    END IF;                    IF NOT END_OF_FILE (FILE_CHR) THEN                         FAILED ("WRONG END_OF_FILE VALUE FOR TYPE " &                                 "CHARACTER");                    END IF;                    SET_INDEX (FILE_CHR,ONE_CHR);                    IF INDEX (FILE_CHR) /= ONE_CHR THEN                         FAILED ("WRONG INDEX VALUE FOR TYPE " &                                 "CHARACTER");                    END IF;               END;               CLOSE (FILE_CHR);               BEGIN                    OPEN (FILE_CHR, 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_CHR,ITEM_CHR);                    IF ITEM_CHR /= CHR THEN                         FAILED ("INCORRECT CHR VALUE READ - 1");                    END IF;               EXCEPTION                    WHEN OTHERS =>                         FAILED ("READ WITHOUT FROM FOR " &                                 "TYPE CHARACTER");               END;               BEGIN                    READ (FILE_CHR,ITEM_CHR,ONE_CHR);                    IF ITEM_CHR /= CHR THEN                         FAILED ("INCORRECT CHR VALUE READ - 2");                    END IF;               EXCEPTION                    WHEN OTHERS =>                         FAILED ("READ WITH FROM FOR " &                                 "TYPE CHARACTER");               END;          END;          BEGIN               DELETE (FILE_CHR);          EXCEPTION               WHEN USE_ERROR =>                    NULL;          END;     EXCEPTION          WHEN END_SUBTEST =>               NULL;     END;     DECLARE          PACKAGE DIR_INT IS NEW DIRECT_IO (INTEGER);          USE DIR_INT;          FILE_INT : FILE_TYPE;     BEGIN          BEGIN               CREATE (FILE_INT, INOUT_FILE, LEGAL_FILE_NAME(3));          EXCEPTION               WHEN USE_ERROR | NAME_ERROR =>                    NOT_APPLICABLE ("USE_ERROR | NAME_ERROR RAISED " &                                    "ON CREATE - INTEGER");                    RAISE END_SUBTEST;               WHEN OTHERS =>                    FAILED ("UNEXPECTED ERROR RAISED ON " &                            "CREATE - INTEGER");                    RAISE END_SUBTEST;          END;          DECLARE               INT : INTEGER := IDENT_INT (33);               ITEM_INT : INTEGER;               ONE_INT : POSITIVE_COUNT := 1;               TWO_INT : POSITIVE_COUNT := 2;          BEGIN               BEGIN                    WRITE (FILE_INT,INT);               EXCEPTION                    WHEN OTHERS =>                         FAILED ("EXCEPTION RAISED ON WRITE FOR " &                                 "INTEGER - 1");               END;               BEGIN                    WRITE (FILE_INT,INT,TWO_INT);               EXCEPTION                    WHEN OTHERS =>                         FAILED ("EXCEPTION RAISED ON WRITE FOR " &                                 "INTEGER - 2");               END;               BEGIN                    IF SIZE (FILE_INT) /= TWO_INT THEN                         FAILED ("SIZE FOR TYPE INTEGER");                    END IF;                    IF NOT END_OF_FILE (FILE_INT) THEN                         FAILED ("WRONG END_OF_FILE VALUE FOR TYPE " &                                 "INTEGER");                    END IF;                    SET_INDEX (FILE_INT, ONE_INT);                    IF INDEX (FILE_INT) /= ONE_INT THEN                         FAILED ("WRONG INDEX VALUE FOR TYPE INTEGER");                    END IF;               END;               CLOSE (FILE_INT);               BEGIN                    OPEN (FILE_INT, IN_FILE, LEGAL_FILE_NAME(3));               EXCEPTION                    WHEN USE_ERROR =>                         NOT_APPLICABLE ("OPEN FOR IN_FILE MODE " &                                         "NOT SUPPORTED - 3");                         RAISE END_SUBTEST;               END;               BEGIN                    READ (FILE_INT,ITEM_INT);                    IF ITEM_INT /= INT THEN                         FAILED ("INCORRECT INT VALUE READ - 1");                    END IF;               EXCEPTION                    WHEN OTHERS =>                         FAILED ("READ WITHOUT FROM FOR " &                                 "TYPE INTEGER");               END;               BEGIN                    READ (FILE_INT,ITEM_INT,ONE_INT);                    IF ITEM_INT /= INT THEN                         FAILED ("INCORRECT INT VALUE READ - 2");                    END IF;               EXCEPTION                    WHEN OTHERS =>                         FAILED ("READ WITH FROM FOR " &                                 "TYPE INTEGER");               END;          END;          BEGIN               DELETE (FILE_INT);          EXCEPTION               WHEN USE_ERROR =>                    NULL;          END;     EXCEPTION          WHEN END_SUBTEST =>               NULL;     END;     RESULT;END CE2401A;

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?