-- C48009E.ADA
|
-- C48009E.ADA
|
|
|
-- Grant of Unlimited Rights
|
-- Grant of Unlimited Rights
|
--
|
--
|
-- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
|
-- 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
|
-- 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 in the software and documentation contained herein.
|
-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
|
-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
|
-- this public release, the Government intends to confer upon all
|
-- this public release, the Government intends to confer upon all
|
-- recipients unlimited rights equal to those held by the Government.
|
-- recipients unlimited rights equal to those held by the Government.
|
-- These rights include rights to use, duplicate, release or disclose the
|
-- These rights include rights to use, duplicate, release or disclose the
|
-- released technical data and computer software in whole or in part, in
|
-- 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
|
-- any manner and for any purpose whatsoever, and to have or permit others
|
-- to do so.
|
-- to do so.
|
--
|
--
|
-- DISCLAIMER
|
-- DISCLAIMER
|
--
|
--
|
-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
|
-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
|
-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
|
-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
|
-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
|
-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
|
-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
|
-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
|
-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
|
-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
|
-- PARTICULAR PURPOSE OF SAID MATERIAL.
|
-- PARTICULAR PURPOSE OF SAID MATERIAL.
|
--*
|
--*
|
-- FOR ALLOCATORS OF THE FORM "NEW T'(X)", CHECK THAT CONSTRAINT_ERROR
|
-- FOR ALLOCATORS OF THE FORM "NEW T'(X)", CHECK THAT CONSTRAINT_ERROR
|
-- IS RAISED IF T IS A CONSTRAINED ARRAY TYPE AND:
|
-- IS RAISED IF T IS A CONSTRAINED ARRAY TYPE AND:
|
-- 1) A NAMED NULL OR NON-NULL BOUND FOR X DOES NOT EQUAL THE
|
-- 1) A NAMED NULL OR NON-NULL BOUND FOR X DOES NOT EQUAL THE
|
-- CORRESPONDING BOUND FOR T;
|
-- CORRESPONDING BOUND FOR T;
|
-- 2) A BOUND OF T DOES NOT EQUAL THE CORRESPONDING VALUE SPECIFIED IN
|
-- 2) A BOUND OF T DOES NOT EQUAL THE CORRESPONDING VALUE SPECIFIED IN
|
-- THE DECLARATION OF THE ALLOCATOR'S BASE TYPE;
|
-- THE DECLARATION OF THE ALLOCATOR'S BASE TYPE;
|
-- 3) A POSITIONAL AGGREGATE DOES NOT HAVE THE NUMBER OF COMPONENTS
|
-- 3) A POSITIONAL AGGREGATE DOES NOT HAVE THE NUMBER OF COMPONENTS
|
-- REQUIRED BY T OR BY THE ALLOCATOR'S BASE TYPE.
|
-- REQUIRED BY T OR BY THE ALLOCATOR'S BASE TYPE.
|
|
|
-- RM 01/08/80
|
-- RM 01/08/80
|
-- NL 10/13/81
|
-- NL 10/13/81
|
-- SPS 10/26/82
|
-- SPS 10/26/82
|
-- JBG 03/03/83
|
-- JBG 03/03/83
|
-- EG 07/05/84
|
-- EG 07/05/84
|
-- PWN 11/30/94 REMOVED TEST ILLEGAL IN ADA 9X.
|
-- 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/14/95 CHANGED FAILURE AT SLIDING ASSIGNMENT TO COMMENT ON LANGUAGE
|
-- KAS 11/30/95 REINSTRUMENTED CASES TO SELECT LANGUAGE SEMANTICS
|
-- KAS 11/30/95 REINSTRUMENTED CASES TO SELECT LANGUAGE SEMANTICS
|
-- PWN 05/03/96 Enforced Ada 95 sliding rules
|
-- PWN 05/03/96 Enforced Ada 95 sliding rules
|
-- PWN 10/24/96 Adjusted expected results for Ada 95.
|
-- PWN 10/24/96 Adjusted expected results for Ada 95.
|
-- TMB 11/19/96 BACKED OUT CHANGE FOR SLIDING WITH ACCESS TYPES
|
-- 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
|
-- MRM 12/16/96 Removed problem code from withdrawn version of test, and
|
-- implemented a dereference-index check to ensure Ada95
|
-- implemented a dereference-index check to ensure Ada95
|
-- required behavior.
|
-- required behavior.
|
-- PWB.CTA 03/07/97 Restored checks from 1.11 in 2 cases where sliding does
|
-- PWB.CTA 03/07/97 Restored checks from 1.11 in 2 cases where sliding does
|
-- not occur
|
-- not occur
|
WITH REPORT;
|
WITH REPORT;
|
|
|
PROCEDURE C48009E IS
|
PROCEDURE C48009E IS
|
|
|
USE REPORT ;
|
USE REPORT ;
|
|
|
BEGIN
|
BEGIN
|
|
|
TEST("C48009E","FOR ALLOCATORS OF THE FORM 'NEW T'(X)', CHECK " &
|
TEST("C48009E","FOR ALLOCATORS OF THE FORM 'NEW T'(X)', CHECK " &
|
"THAT CONSTRAINT_ERROR IS RAISED WHEN " &
|
"THAT CONSTRAINT_ERROR IS RAISED WHEN " &
|
"APPROPRIATE - CONSTRAINED ARRAY TYPES");
|
"APPROPRIATE - CONSTRAINED ARRAY TYPES");
|
DECLARE
|
DECLARE
|
|
|
TYPE UA IS ARRAY(INTEGER RANGE <>) OF INTEGER;
|
TYPE UA IS ARRAY(INTEGER RANGE <>) OF INTEGER;
|
TYPE CA3_2 IS ARRAY(3 .. 2) OF INTEGER;
|
TYPE CA3_2 IS ARRAY(3 .. 2) OF INTEGER;
|
TYPE SA1_3 IS ARRAY(1 .. 3) OF INTEGER;
|
TYPE SA1_3 IS ARRAY(1 .. 3) OF INTEGER;
|
TYPE NA1_3 IS ARRAY(1 .. IDENT_INT(3)) OF INTEGER;
|
TYPE NA1_3 IS ARRAY(1 .. IDENT_INT(3)) OF INTEGER;
|
SUBTYPE CA2_6 IS UA(2 .. 6);
|
SUBTYPE CA2_6 IS UA(2 .. 6);
|
SUBTYPE CA1_4 IS UA(1 .. 4);
|
SUBTYPE CA1_4 IS UA(1 .. 4);
|
SUBTYPE CA1_6 IS UA(1 .. 6);
|
SUBTYPE CA1_6 IS UA(1 .. 6);
|
SUBTYPE CA4_1 IS UA(4 .. 1);
|
SUBTYPE CA4_1 IS UA(4 .. 1);
|
SUBTYPE CA4_2 IS UA(4 .. 2);
|
SUBTYPE CA4_2 IS UA(4 .. 2);
|
|
|
TYPE A_CA3_2 IS ACCESS CA3_2;
|
TYPE A_CA3_2 IS ACCESS CA3_2;
|
TYPE A_SA1_3 IS ACCESS SA1_3;
|
TYPE A_SA1_3 IS ACCESS SA1_3;
|
TYPE A_NA1_3 IS ACCESS NA1_3;
|
TYPE A_NA1_3 IS ACCESS NA1_3;
|
TYPE A_CA1_5 IS ACCESS UA(1 .. 5);
|
TYPE A_CA1_5 IS ACCESS UA(1 .. 5);
|
TYPE A_CA4_2 IS ACCESS CA4_2;
|
TYPE A_CA4_2 IS ACCESS CA4_2;
|
|
|
V_A_CA3_2 : A_CA3_2;
|
V_A_CA3_2 : A_CA3_2;
|
V_A_SA1_3 : A_SA1_3;
|
V_A_SA1_3 : A_SA1_3;
|
V_A_NA1_3 : A_NA1_3;
|
V_A_NA1_3 : A_NA1_3;
|
V_A_CA1_5 : A_CA1_5;
|
V_A_CA1_5 : A_CA1_5;
|
|
|
FUNCTION ALLOC1(X : CA2_6) RETURN A_CA1_5 IS
|
FUNCTION ALLOC1(X : CA2_6) RETURN A_CA1_5 IS
|
BEGIN
|
BEGIN
|
IF EQUAL(1, 1) THEN
|
IF EQUAL(1, 1) THEN
|
RETURN NEW CA2_6'(X);
|
RETURN NEW CA2_6'(X);
|
ELSE
|
ELSE
|
RETURN NULL;
|
RETURN NULL;
|
END IF;
|
END IF;
|
END ALLOC1;
|
END ALLOC1;
|
FUNCTION ALLOC2(X : CA4_1) RETURN A_CA4_2 IS
|
FUNCTION ALLOC2(X : CA4_1) RETURN A_CA4_2 IS
|
BEGIN
|
BEGIN
|
IF EQUAL(1, 1) THEN
|
IF EQUAL(1, 1) THEN
|
RETURN NEW CA4_1'(X);
|
RETURN NEW CA4_1'(X);
|
ELSE
|
ELSE
|
RETURN NULL;
|
RETURN NULL;
|
END IF;
|
END IF;
|
END ALLOC2;
|
END ALLOC2;
|
|
|
BEGIN
|
BEGIN
|
|
|
BEGIN
|
BEGIN
|
V_A_CA3_2 := NEW CA3_2'(IDENT_INT(4) .. IDENT_INT(2)
|
V_A_CA3_2 := NEW CA3_2'(IDENT_INT(4) .. IDENT_INT(2)
|
=> 5);
|
=> 5);
|
FAILED ("NO EXCEPTION RAISED - CASE 1A");
|
FAILED ("NO EXCEPTION RAISED - CASE 1A");
|
EXCEPTION
|
EXCEPTION
|
WHEN CONSTRAINT_ERROR =>
|
WHEN CONSTRAINT_ERROR =>
|
NULL;
|
NULL;
|
WHEN OTHERS =>
|
WHEN OTHERS =>
|
FAILED ("WRONG EXCEPTION RAISED - CASE 1A");
|
FAILED ("WRONG EXCEPTION RAISED - CASE 1A");
|
END;
|
END;
|
|
|
BEGIN
|
BEGIN
|
V_A_NA1_3 := NEW NA1_3'(1 .. IDENT_INT(2) => 4);
|
V_A_NA1_3 := NEW NA1_3'(1 .. IDENT_INT(2) => 4);
|
FAILED ("NO EXCEPTION RAISED - CASE 1B");
|
FAILED ("NO EXCEPTION RAISED - CASE 1B");
|
EXCEPTION
|
EXCEPTION
|
WHEN CONSTRAINT_ERROR =>
|
WHEN CONSTRAINT_ERROR =>
|
NULL;
|
NULL;
|
WHEN OTHERS =>
|
WHEN OTHERS =>
|
FAILED ("WRONG EXCEPTION RAISED - CASE 1B");
|
FAILED ("WRONG EXCEPTION RAISED - CASE 1B");
|
END;
|
END;
|
|
|
BEGIN
|
BEGIN
|
-- note that ALLOC1 returns A_CA1_5, so both
|
-- note that ALLOC1 returns A_CA1_5, so both
|
-- (1) and (5) are valid index references!
|
-- (1) and (5) are valid index references!
|
IF ALLOC1((2 .. 6 => 2))(5) /= 2 THEN
|
IF ALLOC1((2 .. 6 => 2))(5) /= 2 THEN
|
FAILED ("Wrong Value Returned - CASE 2A");
|
FAILED ("Wrong Value Returned - CASE 2A");
|
ELSIF ALLOC1((2 .. 6 => 3))(1) /= 3 THEN
|
ELSIF ALLOC1((2 .. 6 => 3))(1) /= 3 THEN
|
FAILED ("Unlikely Index Case - CASE 2A");
|
FAILED ("Unlikely Index Case - CASE 2A");
|
END IF;
|
END IF;
|
EXCEPTION
|
EXCEPTION
|
WHEN OTHERS =>
|
WHEN OTHERS =>
|
FAILED ("EXCEPTION RAISED - CASE 2A");
|
FAILED ("EXCEPTION RAISED - CASE 2A");
|
END;
|
END;
|
|
|
BEGIN
|
BEGIN
|
IF ALLOC2((4 .. 1 => 3)) = NULL THEN
|
IF ALLOC2((4 .. 1 => 3)) = NULL THEN
|
FAILED ("IMPOSSIBLE - CASE 2B");
|
FAILED ("IMPOSSIBLE - CASE 2B");
|
END IF;
|
END IF;
|
COMMENT ("ADA 95 SLIDING ASSIGNMENT");
|
COMMENT ("ADA 95 SLIDING ASSIGNMENT");
|
EXCEPTION
|
EXCEPTION
|
WHEN CONSTRAINT_ERROR =>
|
WHEN CONSTRAINT_ERROR =>
|
FAILED ("ADA 83 NON-SLIDING ASSIGNMENT");
|
FAILED ("ADA 83 NON-SLIDING ASSIGNMENT");
|
WHEN OTHERS =>
|
WHEN OTHERS =>
|
FAILED ("WRONG EXCEPTION RAISED - CASE 2B");
|
FAILED ("WRONG EXCEPTION RAISED - CASE 2B");
|
END;
|
END;
|
|
|
BEGIN
|
BEGIN
|
V_A_SA1_3 := NEW SA1_3'(1, 2);
|
V_A_SA1_3 := NEW SA1_3'(1, 2);
|
FAILED ("NO EXCEPTION RAISED - CASE 3A");
|
FAILED ("NO EXCEPTION RAISED - CASE 3A");
|
EXCEPTION
|
EXCEPTION
|
WHEN CONSTRAINT_ERROR =>
|
WHEN CONSTRAINT_ERROR =>
|
NULL;
|
NULL;
|
WHEN OTHERS =>
|
WHEN OTHERS =>
|
FAILED ("WRONG EXCEPTION RAISED - CASE 3A");
|
FAILED ("WRONG EXCEPTION RAISED - CASE 3A");
|
END;
|
END;
|
|
|
BEGIN
|
BEGIN
|
V_A_SA1_3 := NEW SA1_3'(3, 4, 5, 6);
|
V_A_SA1_3 := NEW SA1_3'(3, 4, 5, 6);
|
FAILED ("NO EXCEPTION RAISED - CASE 3B");
|
FAILED ("NO EXCEPTION RAISED - CASE 3B");
|
EXCEPTION
|
EXCEPTION
|
WHEN CONSTRAINT_ERROR =>
|
WHEN CONSTRAINT_ERROR =>
|
NULL;
|
NULL;
|
WHEN OTHERS =>
|
WHEN OTHERS =>
|
FAILED ("WRONG EXCEPTION RAISED - CASE 3B");
|
FAILED ("WRONG EXCEPTION RAISED - CASE 3B");
|
END;
|
END;
|
|
|
BEGIN
|
BEGIN
|
V_A_NA1_3 := NEW NA1_3'(1, 2);
|
V_A_NA1_3 := NEW NA1_3'(1, 2);
|
FAILED ("NO EXCEPTION RAISED - CASE 3C");
|
FAILED ("NO EXCEPTION RAISED - CASE 3C");
|
EXCEPTION
|
EXCEPTION
|
WHEN CONSTRAINT_ERROR =>
|
WHEN CONSTRAINT_ERROR =>
|
NULL;
|
NULL;
|
WHEN OTHERS =>
|
WHEN OTHERS =>
|
FAILED ("WRONG EXCEPTION RAISED - CASE 3C");
|
FAILED ("WRONG EXCEPTION RAISED - CASE 3C");
|
END;
|
END;
|
|
|
BEGIN -- SATISFIES T BUT NOT BASE TYPE.
|
BEGIN -- SATISFIES T BUT NOT BASE TYPE.
|
V_A_CA1_5 := NEW CA1_4'(1, 2, 3, 4);
|
V_A_CA1_5 := NEW CA1_4'(1, 2, 3, 4);
|
FAILED ("NO EXCEPTION RAISED - CASE 3D");
|
FAILED ("NO EXCEPTION RAISED - CASE 3D");
|
EXCEPTION
|
EXCEPTION
|
WHEN CONSTRAINT_ERROR =>
|
WHEN CONSTRAINT_ERROR =>
|
NULL;
|
NULL;
|
WHEN OTHERS =>
|
WHEN OTHERS =>
|
FAILED ("WRONG EXCEPTION RAISED - CASE 3D");
|
FAILED ("WRONG EXCEPTION RAISED - CASE 3D");
|
END;
|
END;
|
|
|
BEGIN -- SATISFIES T BUT NOT BASE TYPE.
|
BEGIN -- SATISFIES T BUT NOT BASE TYPE.
|
V_A_CA1_5 := NEW CA1_6'(1, 2, 3, 4, 5, 6);
|
V_A_CA1_5 := NEW CA1_6'(1, 2, 3, 4, 5, 6);
|
FAILED ("NO EXCEPTION RAISED - CASE 3E");
|
FAILED ("NO EXCEPTION RAISED - CASE 3E");
|
EXCEPTION
|
EXCEPTION
|
WHEN CONSTRAINT_ERROR =>
|
WHEN CONSTRAINT_ERROR =>
|
NULL;
|
NULL;
|
WHEN OTHERS =>
|
WHEN OTHERS =>
|
FAILED ("WRONG EXCEPTION RAISED - CASE 3E");
|
FAILED ("WRONG EXCEPTION RAISED - CASE 3E");
|
END;
|
END;
|
|
|
BEGIN -- SATISFIES BASE TYPE BUT NOT T.
|
BEGIN -- SATISFIES BASE TYPE BUT NOT T.
|
V_A_CA1_5 := NEW CA1_4'(1, 2, 3, 4, 5);
|
V_A_CA1_5 := NEW CA1_4'(1, 2, 3, 4, 5);
|
FAILED ("NO EXCEPTION RAISED - CASE 3F");
|
FAILED ("NO EXCEPTION RAISED - CASE 3F");
|
EXCEPTION
|
EXCEPTION
|
WHEN CONSTRAINT_ERROR =>
|
WHEN CONSTRAINT_ERROR =>
|
NULL;
|
NULL;
|
WHEN OTHERS =>
|
WHEN OTHERS =>
|
FAILED ("WRONG EXCEPTION RAISED - CASE 3F");
|
FAILED ("WRONG EXCEPTION RAISED - CASE 3F");
|
END;
|
END;
|
|
|
BEGIN -- SATISFIES BASE TYPE BUT NOT T.
|
BEGIN -- SATISFIES BASE TYPE BUT NOT T.
|
V_A_CA1_5 := NEW CA1_6'(1, 2, 3, 4, 5);
|
V_A_CA1_5 := NEW CA1_6'(1, 2, 3, 4, 5);
|
FAILED ("NO EXCEPTION RAISED - CASE 3G");
|
FAILED ("NO EXCEPTION RAISED - CASE 3G");
|
EXCEPTION
|
EXCEPTION
|
WHEN CONSTRAINT_ERROR =>
|
WHEN CONSTRAINT_ERROR =>
|
NULL;
|
NULL;
|
WHEN OTHERS =>
|
WHEN OTHERS =>
|
FAILED ("WRONG EXCEPTION RAISED - CASE 3G");
|
FAILED ("WRONG EXCEPTION RAISED - CASE 3G");
|
END;
|
END;
|
|
|
END ;
|
END ;
|
|
|
RESULT ;
|
RESULT ;
|
|
|
END C48009E ;
|
END C48009E ;
|
|
|
|
|