| -- C48009E.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. |
| --* |
| -- FOR ALLOCATORS OF THE FORM "NEW T'(X)", CHECK THAT CONSTRAINT_ERROR |
| -- IS RAISED IF T IS A CONSTRAINED ARRAY TYPE AND: |
| -- 1) A NAMED NULL OR NON-NULL BOUND FOR X DOES NOT EQUAL THE |
| -- CORRESPONDING BOUND FOR T; |
| -- 2) A BOUND OF T DOES NOT EQUAL THE CORRESPONDING VALUE SPECIFIED IN |
| -- THE DECLARATION OF THE ALLOCATOR'S BASE TYPE; |
| -- 3) A POSITIONAL AGGREGATE DOES NOT HAVE THE NUMBER OF COMPONENTS |
| -- REQUIRED BY T OR BY THE ALLOCATOR'S BASE TYPE. |
| |
| -- RM 01/08/80 |
| -- NL 10/13/81 |
| -- SPS 10/26/82 |
| -- JBG 03/03/83 |
| -- EG 07/05/84 |
| -- PWN 11/30/94 REMOVED TEST ILLEGAL IN ADA 9X. |
| -- KAS 11/14/95 CHANGED FAILURE AT SLIDING ASSIGNMENT TO COMMENT ON LANGUAGE |
| -- KAS 11/30/95 REINSTRUMENTED CASES TO SELECT LANGUAGE SEMANTICS |
| -- PWN 05/03/96 Enforced Ada 95 sliding rules |
| -- PWN 10/24/96 Adjusted expected results for Ada 95. |
| -- TMB 11/19/96 BACKED OUT CHANGE FOR SLIDING WITH ACCESS TYPES |
| -- MRM 12/16/96 Removed problem code from withdrawn version of test, and |
| -- implemented a dereference-index check to ensure Ada95 |
| -- required behavior. |
| -- PWB.CTA 03/07/97 Restored checks from 1.11 in 2 cases where sliding does |
| -- not occur |
| WITH REPORT; |
| |
| PROCEDURE C48009E IS |
| |
| USE REPORT ; |
| |
| BEGIN |
| |
| TEST("C48009E","FOR ALLOCATORS OF THE FORM 'NEW T'(X)', CHECK " & |
| "THAT CONSTRAINT_ERROR IS RAISED WHEN " & |
| "APPROPRIATE - CONSTRAINED ARRAY TYPES"); |
| DECLARE |
| |
| TYPE UA IS ARRAY(INTEGER RANGE <>) OF INTEGER; |
| TYPE CA3_2 IS ARRAY(3 .. 2) OF INTEGER; |
| TYPE SA1_3 IS ARRAY(1 .. 3) OF INTEGER; |
| TYPE NA1_3 IS ARRAY(1 .. IDENT_INT(3)) OF INTEGER; |
| SUBTYPE CA2_6 IS UA(2 .. 6); |
| SUBTYPE CA1_4 IS UA(1 .. 4); |
| SUBTYPE CA1_6 IS UA(1 .. 6); |
| SUBTYPE CA4_1 IS UA(4 .. 1); |
| SUBTYPE CA4_2 IS UA(4 .. 2); |
| |
| TYPE A_CA3_2 IS ACCESS CA3_2; |
| TYPE A_SA1_3 IS ACCESS SA1_3; |
| TYPE A_NA1_3 IS ACCESS NA1_3; |
| TYPE A_CA1_5 IS ACCESS UA(1 .. 5); |
| TYPE A_CA4_2 IS ACCESS CA4_2; |
| |
| V_A_CA3_2 : A_CA3_2; |
| V_A_SA1_3 : A_SA1_3; |
| V_A_NA1_3 : A_NA1_3; |
| V_A_CA1_5 : A_CA1_5; |
| |
| FUNCTION ALLOC1(X : CA2_6) RETURN A_CA1_5 IS |
| BEGIN |
| IF EQUAL(1, 1) THEN |
| RETURN NEW CA2_6'(X); |
| ELSE |
| RETURN NULL; |
| END IF; |
| END ALLOC1; |
| FUNCTION ALLOC2(X : CA4_1) RETURN A_CA4_2 IS |
| BEGIN |
| IF EQUAL(1, 1) THEN |
| RETURN NEW CA4_1'(X); |
| ELSE |
| RETURN NULL; |
| END IF; |
| END ALLOC2; |
| |
| BEGIN |
| |
| BEGIN |
| V_A_CA3_2 := NEW CA3_2'(IDENT_INT(4) .. IDENT_INT(2) |
| => 5); |
| FAILED ("NO EXCEPTION RAISED - CASE 1A"); |
| EXCEPTION |
| WHEN CONSTRAINT_ERROR => |
| NULL; |
| WHEN OTHERS => |
| FAILED ("WRONG EXCEPTION RAISED - CASE 1A"); |
| END; |
| |
| BEGIN |
| V_A_NA1_3 := NEW NA1_3'(1 .. IDENT_INT(2) => 4); |
| FAILED ("NO EXCEPTION RAISED - CASE 1B"); |
| EXCEPTION |
| WHEN CONSTRAINT_ERROR => |
| NULL; |
| WHEN OTHERS => |
| FAILED ("WRONG EXCEPTION RAISED - CASE 1B"); |
| END; |
| |
| BEGIN |
| -- note that ALLOC1 returns A_CA1_5, so both |
| -- (1) and (5) are valid index references! |
| IF ALLOC1((2 .. 6 => 2))(5) /= 2 THEN |
| FAILED ("Wrong Value Returned - CASE 2A"); |
| ELSIF ALLOC1((2 .. 6 => 3))(1) /= 3 THEN |
| FAILED ("Unlikely Index Case - CASE 2A"); |
| END IF; |
| EXCEPTION |
| WHEN OTHERS => |
| FAILED ("EXCEPTION RAISED - CASE 2A"); |
| END; |
| |
| BEGIN |
| IF ALLOC2((4 .. 1 => 3)) = NULL THEN |
| FAILED ("IMPOSSIBLE - CASE 2B"); |
| END IF; |
| COMMENT ("ADA 95 SLIDING ASSIGNMENT"); |
| EXCEPTION |
| WHEN CONSTRAINT_ERROR => |
| FAILED ("ADA 83 NON-SLIDING ASSIGNMENT"); |
| WHEN OTHERS => |
| FAILED ("WRONG EXCEPTION RAISED - CASE 2B"); |
| END; |
| |
| BEGIN |
| V_A_SA1_3 := NEW SA1_3'(1, 2); |
| FAILED ("NO EXCEPTION RAISED - CASE 3A"); |
| EXCEPTION |
| WHEN CONSTRAINT_ERROR => |
| NULL; |
| WHEN OTHERS => |
| FAILED ("WRONG EXCEPTION RAISED - CASE 3A"); |
| END; |
| |
| BEGIN |
| V_A_SA1_3 := NEW SA1_3'(3, 4, 5, 6); |
| FAILED ("NO EXCEPTION RAISED - CASE 3B"); |
| EXCEPTION |
| WHEN CONSTRAINT_ERROR => |
| NULL; |
| WHEN OTHERS => |
| FAILED ("WRONG EXCEPTION RAISED - CASE 3B"); |
| END; |
| |
| BEGIN |
| V_A_NA1_3 := NEW NA1_3'(1, 2); |
| FAILED ("NO EXCEPTION RAISED - CASE 3C"); |
| EXCEPTION |
| WHEN CONSTRAINT_ERROR => |
| NULL; |
| WHEN OTHERS => |
| FAILED ("WRONG EXCEPTION RAISED - CASE 3C"); |
| END; |
| |
| BEGIN -- SATISFIES T BUT NOT BASE TYPE. |
| V_A_CA1_5 := NEW CA1_4'(1, 2, 3, 4); |
| FAILED ("NO EXCEPTION RAISED - CASE 3D"); |
| EXCEPTION |
| WHEN CONSTRAINT_ERROR => |
| NULL; |
| WHEN OTHERS => |
| FAILED ("WRONG EXCEPTION RAISED - CASE 3D"); |
| END; |
| |
| BEGIN -- SATISFIES T BUT NOT BASE TYPE. |
| V_A_CA1_5 := NEW CA1_6'(1, 2, 3, 4, 5, 6); |
| FAILED ("NO EXCEPTION RAISED - CASE 3E"); |
| EXCEPTION |
| WHEN CONSTRAINT_ERROR => |
| NULL; |
| WHEN OTHERS => |
| FAILED ("WRONG EXCEPTION RAISED - CASE 3E"); |
| END; |
| |
| BEGIN -- SATISFIES BASE TYPE BUT NOT T. |
| V_A_CA1_5 := NEW CA1_4'(1, 2, 3, 4, 5); |
| FAILED ("NO EXCEPTION RAISED - CASE 3F"); |
| EXCEPTION |
| WHEN CONSTRAINT_ERROR => |
| NULL; |
| WHEN OTHERS => |
| FAILED ("WRONG EXCEPTION RAISED - CASE 3F"); |
| END; |
| |
| BEGIN -- SATISFIES BASE TYPE BUT NOT T. |
| V_A_CA1_5 := NEW CA1_6'(1, 2, 3, 4, 5); |
| FAILED ("NO EXCEPTION RAISED - CASE 3G"); |
| EXCEPTION |
| WHEN CONSTRAINT_ERROR => |
| NULL; |
| WHEN OTHERS => |
| FAILED ("WRONG EXCEPTION RAISED - CASE 3G"); |
| END; |
| |
| END ; |
| |
| RESULT ; |
| |
| END C48009E ; |
| |