blob: d86761d7e68baf008b8d34d0bca462e479bde630 [file] [log] [blame]
-- A85007D.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.
--*
-- CHECK THAT 'FIRST, 'LAST, 'LENGTH, 'RANGE, 'ADDRESS, 'CONSTRAINED,
-- AND 'SIZE CAN BE APPLIED TO RENAMED NON-ACCESS OUT FORMAL PARAMETERS
-- AND RENAMED COMPONENTS OF NON-ACCESS OUT PARAMETERS.
-- SPS 02/21/84 (SEE A62006D-B.ADA)
-- EG 02/22/84
-- EG 05/30/84
-- JBG 12/2/84
WITH REPORT; USE REPORT;
WITH SYSTEM;
PROCEDURE A85007D IS
PROCEDURE Q (X : SYSTEM.ADDRESS) IS
BEGIN
NULL;
END Q;
BEGIN
TEST ("A85007D", "CHECK THAT ATTRIBUTES MAY BE APPLIED TO " &
"RENAMED NON-ACCESS FORMAL OUT PARAMETERS");
DECLARE
TYPE ARR IS ARRAY (1 .. 2) OF BOOLEAN;
TYPE REC (D : INTEGER) IS RECORD
Y : BOOLEAN;
X : ARR;
END RECORD;
PROCEDURE PROC (C2 : OUT ARR;
C3 : OUT REC) IS
X : SYSTEM.ADDRESS;
I : INTEGER;
C21 : ARR RENAMES C2;
C22 : ARR RENAMES C21;
C31 : REC RENAMES C3;
C32 : REC RENAMES C31;
C33 : ARR RENAMES C3.X;
C34 : ARR RENAMES C33;
C35 : ARR RENAMES C32.X;
C36 : BOOLEAN RENAMES C3.Y;
C37 : BOOLEAN RENAMES C36;
C38 : BOOLEAN RENAMES C32.Y;
BEGIN
I := C21'LENGTH;
Q(C21'ADDRESS);
I := C21'SIZE;
I := C22'LENGTH;
Q(C22'ADDRESS);
I := C22'SIZE;
FOR I IN C21'RANGE LOOP
NULL;
END LOOP;
FOR I IN C22'RANGE LOOP
NULL;
END LOOP;
FOR I IN C21'FIRST..C21'LAST LOOP
NULL;
END LOOP;
FOR I IN C22'FIRST..C22'LAST LOOP
NULL;
END LOOP;
I := C31.X'LENGTH;
C3.Y := C31'CONSTRAINED;
FOR J IN C31.X'RANGE LOOP
NULL;
END LOOP;
FOR J IN C31.X'FIRST..C31.X'LAST LOOP
NULL;
END LOOP;
I := C32.X'LENGTH;
C31.Y := C32'CONSTRAINED;
FOR J IN C32.X'RANGE LOOP
NULL;
END LOOP;
FOR J IN C32.X'FIRST..C32.X'LAST LOOP
NULL;
END LOOP;
I := C33'LENGTH;
FOR J IN C33'RANGE LOOP
NULL;
END LOOP;
FOR J IN C33'FIRST..C33'LAST LOOP
NULL;
END LOOP;
I := C34'LENGTH;
FOR J IN C34'RANGE LOOP
NULL;
END LOOP;
FOR J IN C34'FIRST..C34'LAST LOOP
NULL;
END LOOP;
I := C35'LENGTH;
FOR J IN C35'RANGE LOOP
NULL;
END LOOP;
FOR J IN C35'FIRST..C35'LAST LOOP
NULL;
END LOOP;
Q(C31.Y'ADDRESS);
I := C31.Y'SIZE;
Q(C32.Y'ADDRESS);
I := C32.Y'SIZE;
Q(C36'ADDRESS);
I := C36'SIZE;
Q(C37'ADDRESS);
I := C37'SIZE;
Q(C38'ADDRESS);
I := C38'SIZE;
END PROC;
BEGIN
NULL;
END;
RESULT;
END A85007D;