URL
https://opencores.org/ocsvn/scarts/scarts/trunk
Subversion Repositories scarts
[/] [scarts/] [trunk/] [toolchain/] [scarts-gcc/] [gcc-4.1.1/] [gcc/] [testsuite/] [ada/] [acats/] [tests/] [cd/] [cd2b11a.ada] - Rev 12
Compare with Previous | Blame | View Log
-- CD2B11A.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 IF A COLLECTION SIZE SPECIFICATION CAN BE GIVEN FOR AN -- ACCESS TYPE, THEN OPERATIONS ON VALUES OF THE ACCESS TYPE ARE NOT -- AFFECTED. -- HISTORY: -- BCB 11/01/88 CREATED ORIGINAL TEST. -- RJW 05/17/89 CHANGED FROM '.DEP' TEST TO '.ADA' TEST. -- ADDED CHECK FOR UNCHECKED_DEALLOCATION. WITH REPORT; USE REPORT; WITH SYSTEM; WITH UNCHECKED_DEALLOCATION; PROCEDURE CD2B11A IS BASIC_SIZE : CONSTANT := 1024; TYPE MAINTYPE IS ARRAY (INTEGER RANGE <>) OF INTEGER; TYPE ACC_TYPE IS ACCESS MAINTYPE; SUBTYPE ACC_RANGE IS ACC_TYPE (1 .. 3); FOR ACC_TYPE'STORAGE_SIZE USE BASIC_SIZE; TYPE RECORD_TYPE IS RECORD COMP : ACC_TYPE; END RECORD; CHECK_TYPE1 : ACC_TYPE; CHECK_TYPE2 : ACC_TYPE; CHECK_TYPE3 : ACC_TYPE(1..3); CHECK_ARRAY : ARRAY (1..2) OF ACC_TYPE; CHECK_RECORD1 : RECORD_TYPE; CHECK_RECORD2 : RECORD_TYPE; CHECK_PARAM1 : ACC_TYPE; CHECK_PARAM2 : ACC_TYPE; CHECK_NULL : ACC_TYPE := NULL; PROCEDURE PROC (ACC1,ACC2 : IN OUT ACC_TYPE) IS BEGIN IF (ACC1.ALL /= ACC2.ALL) THEN FAILED ("INCORRECT VALUES FOR DESIGNATED OBJECTS " & "- 1"); END IF; IF EQUAL (3,3) THEN ACC2 := ACC1; END IF; IF ACC2 /= ACC1 THEN FAILED ("INCORRECT RESULTS FOR RELATIONAL OPERATORS " & "-1"); END IF; IF (ACC1 IN ACC_RANGE) THEN FAILED ("INCORRECT RESULTS FOR MEMBERSHIP TEST - 1"); END IF; END PROC; BEGIN TEST ("CD2B11A", "CHECK THAT IF A COLLECTION SIZE SPECIFICATION " & "CAN BE GIVEN FOR AN ACCESS TYPE, THEN " & "OPERATIONS ON VALUES OF THE ACCESS TYPE ARE " & "NOT AFFECTED"); CHECK_PARAM1 := NEW MAINTYPE'(25,35,45); CHECK_PARAM2 := NEW MAINTYPE'(25,35,45); PROC (CHECK_PARAM1,CHECK_PARAM2); IF ACC_TYPE'STORAGE_SIZE < BASIC_SIZE THEN FAILED ("INCORRECT VALUE FOR ACCESS TYPE STORAGE_SIZE"); END IF; CHECK_TYPE1 := NEW MAINTYPE'(25,35,45); CHECK_TYPE2 := NEW MAINTYPE'(25,35,45); CHECK_TYPE3 := NEW MAINTYPE'(1 => 1,2 => 2,3 => 3); CHECK_ARRAY (1) := NEW MAINTYPE'(25,35,45); CHECK_ARRAY (2) := NEW MAINTYPE'(25,35,45); CHECK_RECORD1.COMP := NEW MAINTYPE'(25,35,45); CHECK_RECORD2.COMP := NEW MAINTYPE'(25,35,45); IF (CHECK_TYPE1.ALL /= CHECK_TYPE2.ALL) THEN FAILED ("INCORRECT VALUES FOR DESIGNATED OBJECTS - 2"); END IF; IF EQUAL (3,3) THEN CHECK_TYPE2 := CHECK_TYPE1; END IF; IF CHECK_TYPE2 /= CHECK_TYPE1 THEN FAILED ("INCORRECT RESULTS FOR RELATIONAL OPERATORS - 2"); END IF; IF (CHECK_TYPE1 IN ACC_RANGE) THEN FAILED ("INCORRECT RESULTS FOR MEMBERSHIP TEST - 2"); END IF; IF (CHECK_ARRAY (1).ALL /= CHECK_ARRAY (2).ALL) THEN FAILED ("INCORRECT VALUES FOR DESIGNATED OBJECTS - 3"); END IF; IF EQUAL (3,3) THEN CHECK_ARRAY (2) := CHECK_ARRAY (1); END IF; IF CHECK_ARRAY (2) /= CHECK_ARRAY (1) THEN FAILED ("INCORRECT RESULTS FOR RELATIONAL OPERATORS - 3"); END IF; IF (CHECK_ARRAY (1) IN ACC_RANGE) THEN FAILED ("INCORRECT RESULTS FOR MEMBERSHIP TEST - 3"); END IF; IF (CHECK_RECORD1.COMP.ALL /= CHECK_RECORD2.COMP.ALL) THEN FAILED ("INCORRECT VALUES FOR DESIGNATED OBJECTS - 4"); END IF; IF EQUAL (3,3) THEN CHECK_RECORD2 := CHECK_RECORD1; END IF; IF CHECK_RECORD2 /= CHECK_RECORD1 THEN FAILED ("INCORRECT RESULTS FOR RELATIONAL OPERATORS - 4"); END IF; IF (CHECK_RECORD1.COMP IN ACC_RANGE) THEN FAILED ("INCORRECT RESULTS FOR MEMBERSHIP TEST - 4"); END IF; IF CHECK_TYPE3'FIRST /= IDENT_INT (1) THEN FAILED ("INCORRECT VALUE FOR CHECK_TYPE3'FIRST"); END IF; IF CHECK_TYPE3'LAST /= IDENT_INT (3) THEN FAILED ("INCORRECT VALUE FOR CHECK_TYPE3'LAST"); END IF; DECLARE TYPE ACC_CHAR IS ACCESS CHARACTER; FOR ACC_CHAR'STORAGE_SIZE USE 128; LIMIT : INTEGER := (ACC_CHAR'STORAGE_SIZE * SYSTEM.STORAGE_UNIT)/CHARACTER'SIZE; ACC_ARRAY : ARRAY (1 .. LIMIT + 1) OF ACC_CHAR; PLACE : INTEGER; PROCEDURE FREE IS NEW UNCHECKED_DEALLOCATION (CHARACTER, ACC_CHAR); BEGIN FOR I IN ACC_ARRAY'RANGE LOOP ACC_ARRAY (IDENT_INT (I)) := NEW CHARACTER' (IDENT_CHAR ((CHARACTER'VAL (I MOD 128)))); PLACE := I; END LOOP; FAILED ("NO EXCEPTION RAISED WHEN COLLECTION SIZE EXCEEDED"); EXCEPTION WHEN STORAGE_ERROR => BEGIN FOR I IN 1 .. PLACE LOOP IF I MOD 2 = 0 THEN FREE (ACC_ARRAY (IDENT_INT (I))); END IF; END LOOP; FOR I IN 1 .. PLACE LOOP IF I MOD 2 = 1 AND THEN IDENT_CHAR (ACC_ARRAY (I).ALL) /= CHARACTER'VAL (I MOD IDENT_INT (128)) THEN FAILED ("INCORRECT VALUE IN ARRAY"); END IF; END LOOP; END; WHEN OTHERS => FAILED ("WRONG EXCEPTION RAISED"); END; RESULT; END CD2B11A;