blob: 4ec422769cf8739a7c422719ecce849ec2cb48cc [file] [log] [blame]
-- 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;