blob: f15bca7d278b1344de9347845237998341b40a88 [file] [log] [blame]
-- C62002A.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 THE COMPONENTS OF ACCESS IN PARAMETERS CAN BE USED AS THE
-- TARGET OF AN ASSIGNMENT STATEMENT OR AS AN ACTUAL PARAMETER OF
-- ANY MODE. SUBTESTS ARE:
-- (A) INTEGER ACCESS TYPE.
-- (B) ARRAY ACCESS TYPE.
-- (C) RECORD ACCESS TYPE.
-- DAS 1/23/81
-- SPS 10/26/82
WITH REPORT;
PROCEDURE C62002A IS
USE REPORT;
BEGIN
TEST ("C62002A", "CHECK THAT COMPONENTS OF ACCESS IN PARAMETERS" &
" MAY BE USED IN ASSIGNMENT CONTEXTS");
--------------------------------------------------
DECLARE -- (A)
TYPE PTRINT IS ACCESS INTEGER;
PI : PTRINT;
PROCEDURE PROCA (PI : IN PTRINT) IS
PROCEDURE PROCA1 (I : OUT INTEGER) IS
BEGIN
I := 7;
END PROCA1;
PROCEDURE PROCA2 (I : IN OUT INTEGER) IS
BEGIN
I := I + 1;
END PROCA2;
BEGIN
PROCA1 (PI.ALL);
PROCA2 (PI.ALL);
PI.ALL := PI.ALL + 1;
IF (PI.ALL /= 9) THEN
FAILED ("ASSIGNMENT TO COMPONENT OF INTEGER" &
" ACCESS PARAMETER FAILED");
END IF;
END PROCA;
BEGIN -- (A)
PI := NEW INTEGER '(0);
PROCA (PI);
END; -- (A)
---------------------------------------------
DECLARE -- (B)
TYPE TBL IS ARRAY (1..3) OF INTEGER;
TYPE PTRTBL IS ACCESS TBL;
PT : PTRTBL;
PROCEDURE PROCB (PT : IN PTRTBL) IS
PROCEDURE PROCB1 (I : OUT INTEGER) IS
BEGIN
I := 7;
END PROCB1;
PROCEDURE PROCB2 (I : IN OUT INTEGER) IS
BEGIN
I := I + 1;
END PROCB2;
PROCEDURE PROCB3 (T : OUT TBL) IS
BEGIN
T := (1,2,3);
END PROCB3;
PROCEDURE PROCB4 (T : IN OUT TBL) IS
BEGIN
T(3) := T(3) - 1;
END PROCB4;
BEGIN
PROCB3 (PT.ALL); -- (1,2,3)
PROCB4 (PT.ALL); -- (1,2,2)
PROCB1 (PT(2)); -- (1,7,2)
PROCB2 (PT(1)); -- (2,7,2)
PT(3) := PT(3) + 7; -- (2,7,9)
IF (PT.ALL /= (2,7,9)) THEN
FAILED ("ASSIGNMENT TO COMPONENT OF ARRAY" &
" ACCESS PARAMETER FAILED");
END IF;
END PROCB;
BEGIN -- (B)
PT := NEW TBL '(0,0,0);
PROCB (PT);
END; -- (B)
---------------------------------------------
DECLARE -- (C)
TYPE REC IS
RECORD
I1 : INTEGER;
I2 : INTEGER;
I3 : INTEGER;
END RECORD;
TYPE PTRREC IS ACCESS REC;
PR : PTRREC;
PROCEDURE PROCC (PR : IN PTRREC) IS
PROCEDURE PROCC1 (I : OUT INTEGER) IS
BEGIN
I := 7;
END PROCC1;
PROCEDURE PROCC2 (I : IN OUT INTEGER) IS
BEGIN
I := I + 1;
END PROCC2;
PROCEDURE PROCC3 (R : OUT REC) IS
BEGIN
R := (1,2,3);
END PROCC3;
PROCEDURE PROCC4 (R : IN OUT REC) IS
BEGIN
R.I3 := R.I3 - 1;
END PROCC4;
BEGIN
PROCC3 (PR.ALL); -- (1,2,3)
PROCC4 (PR.ALL); -- (1,2,2)
PROCC1 (PR.I2); -- (1,7,2)
PROCC2 (PR.I1); -- (2,7,2)
PR.I3 := PR.I3 + 7; -- (2,7,9)
IF (PR.ALL /= (2,7,9)) THEN
FAILED ("ASSIGNMENT TO COMPONENT OF RECORD" &
" ACCESS PARAMETER FAILED");
END IF;
END PROCC;
BEGIN -- (C)
PR := NEW REC '(0,0,0);
PROCC (PR);
END; -- (C)
---------------------------------------------
RESULT;
END C62002A;