comparison gcc/testsuite/ada/acats/tests/c4/c41303o.ada @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
comparison
equal deleted inserted replaced
68:561a7518be6b 111:04ced10e8804
1 -- C41303O.ADA
2
3 -- Grant of Unlimited Rights
4 --
5 -- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
6 -- F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained
7 -- unlimited rights in the software and documentation contained herein.
8 -- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
9 -- this public release, the Government intends to confer upon all
10 -- recipients unlimited rights equal to those held by the Government.
11 -- These rights include rights to use, duplicate, release or disclose the
12 -- released technical data and computer software in whole or in part, in
13 -- any manner and for any purpose whatsoever, and to have or permit others
14 -- to do so.
15 --
16 -- DISCLAIMER
17 --
18 -- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
19 -- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
20 -- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
21 -- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
22 -- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
23 -- PARTICULAR PURPOSE OF SAID MATERIAL.
24 --*
25 -- CHECK THAT THE NOTATION L.ALL IS ALLOWED IF L IS THE NAME OF AN
26 -- ACCESS OBJECT DESIGNATING A RECORD, AN ARRAY, A SCALAR, OR
27 -- ANOTHER ACCESS OBJECT.
28 -- CHECK THAT IF A IS AN IDENTIFIER DENOTING AN ACCESS OBJECT WHICH
29 -- IN TURN DESIGNATES AN ACCESS OBJECT, THE FORM A.ALL.ALL IS
30 -- ACCEPTED.
31
32
33 -- THIS OBJECTIVE IS COVERED IN SEVERAL TESTS. IN THE FOLLOWING DIAGRAM,
34 -- THE PORTION COVERED BY THE CURRENT TEST IS MARKED BY 'X' .
35
36
37 -- || ASSIGNMT | PROC. PARAMETERS
38 -- || ():= :=() | IN OUT IN OUT
39 -- ========================||=============|====================
40 -- ACC REC || |
41 -- --------------||-------------|--------------------
42 -- 1 '.ALL' ACC ARR || |
43 -- --------------||-------------|--------------------
44 -- ACC SCLR || | XXXXXXXXX
45 -- ========================||=============|====================
46 -- ACC ACC REC || |
47 -- --------------||-------------|--------------------
48 -- 1 '.ALL' ACC ACC ARR || |
49 -- --------------||-------------|--------------------
50 -- ACC ACC SCLR || |
51 -- ========================||=============|====================
52 -- ACC ACC REC || |
53 -- --------------||-------------|--------------------
54 -- 2 '.ALL' ACC ACC ARR || |
55 -- --------------||-------------|--------------------
56 -- ACC ACC SCLR || |
57 -- ============================================================
58
59
60 -- RM 1/27/82
61 -- SPS 12/2/82
62
63
64 WITH REPORT;
65 USE REPORT;
66 PROCEDURE C41303O IS
67
68
69 BEGIN
70
71 TEST ( "C41303O" , "CHECK THAT L.ALL , WHERE L IS THE NAME OF"
72 & " AN ACCESS OBJECT DESIGNATING A RECORD, AN"
73 & " ARRAY, OR A SCALAR, IS ALLOWED AS"
74 & " ACTUAL PARAMETER OF ANY MODE" );
75
76
77 -------------------------------------------------------------------
78 -------------------- ACCESS TO SCALAR ---------------------------
79
80 DECLARE
81
82 TYPE NEWINT IS NEW INTEGER ;
83
84 NEWINT_CONST : NEWINT := 813 ;
85 NEWINT_VAR : NEWINT := NEWINT_CONST ;
86 NEWINT_VAR0 : NEWINT := NEWINT_CONST ;
87
88 TYPE ACC_NEWINT IS ACCESS NEWINT ;
89
90 ACC_NEWINT_VAR : ACC_NEWINT := NEW NEWINT'( 707 );
91 ACC_NEWINT_VAR0 : ACC_NEWINT := NEW NEWINT'( 707 );
92
93
94 PROCEDURE R_ASSIGN( R_IN : IN NEWINT ;
95 R_INOUT : IN OUT NEWINT ) IS
96 BEGIN
97 NEWINT_VAR := R_IN ;
98 NEWINT_VAR0 := R_INOUT ;
99 END ;
100
101
102 PROCEDURE L_ASSIGN( L_OUT : OUT NEWINT ;
103 L_INOUT : IN OUT NEWINT ) IS
104 BEGIN
105 L_OUT := NEWINT_CONST ;
106 L_INOUT := NEWINT_CONST ;
107 END ;
108
109
110 BEGIN
111
112 R_ASSIGN( ACC_NEWINT_VAR.ALL , ACC_NEWINT_VAR0.ALL );
113
114 IF NEWINT_VAR /= ( 707 )
115 THEN
116 FAILED( "ACC. NEWINT, RIGHT SIDE (1), WRONG VAL." );
117 END IF;
118
119 IF NEWINT_VAR0 /= ( 707 )
120 THEN
121 FAILED( "ACC. NEWINT, RIGHT SIDE (2), WRONG VAL." );
122 END IF;
123
124
125 L_ASSIGN( ACC_NEWINT_VAR.ALL , ACC_NEWINT_VAR0.ALL );
126
127 IF ACC_NEWINT_VAR.ALL /= 813
128 THEN
129 FAILED( "ACC. NEWINT, LEFT SIDE (1), WRONG VAL." );
130 END IF;
131
132 IF ACC_NEWINT_VAR0.ALL /= 813
133 THEN
134 FAILED( "ACC. NEWINT, LEFT SIDE (2), WRONG VAL." );
135 END IF;
136
137
138 END ;
139
140 -------------------------------------------------------------------
141
142 RESULT;
143
144
145 END C41303O;