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