-- CE2401C.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 ARE IMPLEMENTED FOR DIRECT FILES WITH -- ELEMENT_TYPE CONSTRAINED ARRAY, AND RECORD WITHOUT DISCRIMINANTS. -- APPLICABILITY CRITERIA: -- THIS TEST IS ONLY APPLICABLE TO IMPLEMENTATIONS WHICH SUPPORT -- DIRECT FILES. -- HISTORY: -- ABW 08/18/82 -- SPS 09/20/82 -- SPS 11/09/82 -- JBG 05/02/83 -- JRK 03/26/84 -- EG 05/16/85 -- TBN 11/04/86 REVISED TEST TO OUTPUT A NON_APPLICABLE -- RESULT WHEN FILES ARE NOT SUPPORTED. -- DWC 08/10/87 ISOLATED EXCEPTIONS. WITH REPORT; USE REPORT; WITH DIRECT_IO; PROCEDURE CE2401C IS END_SUBTEST: EXCEPTION; BEGIN TEST ("CE2401C" , "CHECK READ, WRITE, SET_INDEX " & "INDEX, SIZE, AND END_OF_FILE FOR " & "DIRECT FILES FOR CONSTRAINED ARRAY TYPES, " & "AND RECORD TYPES WITHOUT DISCRIMINANTS"); DECLARE TYPE ARR_CN IS ARRAY (1..5) OF BOOLEAN; PACKAGE DIR_ARR_CN IS NEW DIRECT_IO (ARR_CN); USE DIR_ARR_CN; FILE : FILE_TYPE; BEGIN BEGIN CREATE (FILE, INOUT_FILE, LEGAL_FILE_NAME); EXCEPTION WHEN USE_ERROR | NAME_ERROR => NOT_APPLICABLE ("USE_ERROR | NAME_ERROR RAISED " & "ON CREATE - CONSTRAINED ARRAY"); RAISE END_SUBTEST; WHEN OTHERS => FAILED ("UNEXPECTED ERROR RAISED ON " & "CREATE - CONSTRAINED ARRAY"); RAISE END_SUBTEST; END; DECLARE ARR : ARR_CN := (TRUE,TRUE,FALSE,TRUE,TRUE); ITEM : ARR_CN; ONE : POSITIVE_COUNT := 1; TWO : POSITIVE_COUNT := 2; BEGIN BEGIN WRITE (FILE,ARR); EXCEPTION WHEN OTHERS => FAILED ("EXCEPTION RAISED ON WRITE FOR " & "CONTRAINED ARRAY - 1"); END; BEGIN WRITE (FILE,ARR,TWO); EXCEPTION WHEN OTHERS => FAILED ("EXCEPTION RAISED ON WRITE FOR " & "CONSTRAINED ARRAY - 2"); END; BEGIN IF SIZE (FILE) /= TWO THEN FAILED ("SIZE FOR TYPE CONSTRAINED ARRAY"); END IF; IF NOT END_OF_FILE (FILE) THEN FAILED ("WRONG END_OF_FILE VALUE FOR TYPE " & "CONSTRAINED ARRAY"); END IF; SET_INDEX (FILE,ONE); IF INDEX (FILE) /= ONE THEN FAILED ("WRONG INDEX VALUE FOR TYPE " & "CONSTRAINED ARRAY"); END IF; END; CLOSE (FILE); BEGIN OPEN (FILE, 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,ITEM); IF ITEM /= ARR THEN FAILED ("INCORRECT ARRAY VALUES READ " & "- 1"); END IF; EXCEPTION WHEN OTHERS => FAILED ("READ WITHOUT FROM FOR " & "TYPE CONSTRAINED ARRAY"); END; BEGIN READ (FILE,ITEM,ONE); IF ITEM /= ARR THEN FAILED ("INCORRECT ARRAY VALUES READ " & "- 2"); END IF; EXCEPTION WHEN OTHERS => FAILED ("READ WITH FROM FOR " & "TYPE CONSTRAINED ARRAY"); END; END; BEGIN DELETE (FILE); EXCEPTION WHEN USE_ERROR => NULL; END; EXCEPTION WHEN END_SUBTEST => NULL; END; DECLARE TYPE REC IS RECORD ONE : INTEGER; TWO : INTEGER; END RECORD; PACKAGE DIR_REC IS NEW DIRECT_IO (REC); USE DIR_REC; FILE : FILE_TYPE; BEGIN BEGIN CREATE (FILE, INOUT_FILE, LEGAL_FILE_NAME(2)); EXCEPTION WHEN USE_ERROR | NAME_ERROR => NOT_APPLICABLE ("USE_ERROR | NAME_ERROR RAISED " & "ON CREATE - RECORD"); RAISE END_SUBTEST; WHEN OTHERS => FAILED ("UNEXPECTED ERROR RAISED ON CREATE - " & "RECORD"); END; DECLARE REC1 : REC := REC'(ONE=>18,TWO=>36); ITEM : REC; ONE : POSITIVE_COUNT := 1; TWO : POSITIVE_COUNT := 2; BEGIN BEGIN WRITE (FILE,REC1); EXCEPTION WHEN OTHERS => FAILED ("EXCEPTION RAISED ON WRITE FOR - " & "RECORD - 1"); END; BEGIN WRITE (FILE,REC1,TWO); EXCEPTION WHEN OTHERS => FAILED ("EXCEPTION RAISED ON WRITE FOR - " & "RECORD - 2"); END; BEGIN IF SIZE (FILE) /= TWO THEN FAILED ("SIZE FOR TYPE RECORD"); END IF; IF NOT END_OF_FILE (FILE) THEN FAILED ("WRONG END_OF_FILE VALUE FOR RECORD"); END IF; SET_INDEX (FILE,ONE); IF INDEX (FILE) /= ONE THEN FAILED ("WRONG INDEX VALUE FOR TYPE RECORD"); END IF; END; CLOSE (FILE); BEGIN OPEN (FILE, 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,ITEM); IF ITEM /= REC1 THEN FAILED ("INCORRECT RECORD VALUES READ " & "- 1"); END IF; EXCEPTION WHEN OTHERS => FAILED ("READ WITHOUT FROM FOR RECORD"); END; BEGIN READ (FILE,ITEM,ONE); IF ITEM /= REC1 THEN FAILED ("INCORRECT RECORD VALUES READ " & "- 2"); END IF; EXCEPTION WHEN OTHERS => FAILED ("READ WITH FROM FOR " & "TYPE RECORD"); END; END; BEGIN DELETE (FILE); EXCEPTION WHEN USE_ERROR => NULL; END; EXCEPTION WHEN END_SUBTEST => NULL; END; RESULT; END CE2401C;