OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [gcc/] [testsuite/] [ada/] [acats/] [tests/] [ce/] [ce2401a.ada] - Rev 720

Compare with Previous | Blame | View Log

-- 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;
 

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.