annotate gcc/testsuite/ada/acats/tests/c6/c64103e.ada @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 -- C64103E.ADA
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 -- Grant of Unlimited Rights
kono
parents:
diff changeset
4 --
kono
parents:
diff changeset
5 -- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
kono
parents:
diff changeset
6 -- F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained
kono
parents:
diff changeset
7 -- unlimited rights in the software and documentation contained herein.
kono
parents:
diff changeset
8 -- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
kono
parents:
diff changeset
9 -- this public release, the Government intends to confer upon all
kono
parents:
diff changeset
10 -- recipients unlimited rights equal to those held by the Government.
kono
parents:
diff changeset
11 -- These rights include rights to use, duplicate, release or disclose the
kono
parents:
diff changeset
12 -- released technical data and computer software in whole or in part, in
kono
parents:
diff changeset
13 -- any manner and for any purpose whatsoever, and to have or permit others
kono
parents:
diff changeset
14 -- to do so.
kono
parents:
diff changeset
15 --
kono
parents:
diff changeset
16 -- DISCLAIMER
kono
parents:
diff changeset
17 --
kono
parents:
diff changeset
18 -- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
kono
parents:
diff changeset
19 -- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
kono
parents:
diff changeset
20 -- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
kono
parents:
diff changeset
21 -- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
kono
parents:
diff changeset
22 -- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
kono
parents:
diff changeset
23 -- PARTICULAR PURPOSE OF SAID MATERIAL.
kono
parents:
diff changeset
24 --*
kono
parents:
diff changeset
25 -- OBJECTIVE:
kono
parents:
diff changeset
26 -- CHECK THAT, FOR IN-OUT PARAMETERS OF AN ACCESS TYPE,
kono
parents:
diff changeset
27 -- CONSTRAINT_ERROR IS RAISED:
kono
parents:
diff changeset
28 -- BEFORE A SUBPROGRAM CALL WHEN THE BOUNDS OR DISCRIMINANTS
kono
parents:
diff changeset
29 -- OF THE ACTUAL DESIGNATED PARAMETER ARE DIFFERENT FROM
kono
parents:
diff changeset
30 -- THOSE OF THE FORMAL DESIGNATED PARAMETER;
kono
parents:
diff changeset
31 -- AFTER A SUBPROGRAM CALL WHEN THE BOUNDS OR DISCRIMINANTS
kono
parents:
diff changeset
32 -- OF THE FORMAL DESIGNATED PARAMETER ARE DIFFERENT FROM
kono
parents:
diff changeset
33 -- THOSE OF THE ACTUAL DESIGNATED PARAMETER.
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 -- HISTORY:
kono
parents:
diff changeset
36 -- CPP 07/23/84 CREATED ORIGINAL TEST.
kono
parents:
diff changeset
37 -- VCL 10/27/87 MODIFIED THIS HEADER; ADDED STATEMENTS WHICH
kono
parents:
diff changeset
38 -- REFERENCED THE ACTUAL PARAMETERS IN THE SECOND
kono
parents:
diff changeset
39 -- SUBTEST.
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 WITH REPORT; USE REPORT;
kono
parents:
diff changeset
42 PROCEDURE C64103E IS
kono
parents:
diff changeset
43 BEGIN
kono
parents:
diff changeset
44 TEST ("C64103E", "FOR IN-OUT PARAMETERS OF AN ACCESS TYPE, " &
kono
parents:
diff changeset
45 "CONSTRAINT_ERROR IS RAISED: BEFORE A " &
kono
parents:
diff changeset
46 "SUBPROGRAM CALL WHEN THE BOUNDS OR " &
kono
parents:
diff changeset
47 "DISCRIMINANTS OF THE ACTUAL DESIGNATED " &
kono
parents:
diff changeset
48 "PARAMETER ARE DIFFERENT FROM THOSE OF THE " &
kono
parents:
diff changeset
49 "FORMAL DESIGNATED PARAMETER; AFTER A " &
kono
parents:
diff changeset
50 "SUBPROGRAM CALL WHEN THE BOUNDS OR " &
kono
parents:
diff changeset
51 "DISCRIMINANTS OF THE FORMAL DESIGNATED " &
kono
parents:
diff changeset
52 "PARAMETER ARE DIFFERENT FROM THOSE OF THE " &
kono
parents:
diff changeset
53 "ACTUAL DESIGNATED PARAMETER");
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55
kono
parents:
diff changeset
56 BEGIN
kono
parents:
diff changeset
57 DECLARE
kono
parents:
diff changeset
58 TYPE AST IS ACCESS STRING;
kono
parents:
diff changeset
59 SUBTYPE AST_3 IS AST(1..3);
kono
parents:
diff changeset
60 SUBTYPE AST_5 IS AST(3..5);
kono
parents:
diff changeset
61 X_3 : AST_3 := NEW STRING(1..IDENT_INT(3));
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 PROCEDURE P1 (X : IN OUT AST_5) IS
kono
parents:
diff changeset
64 BEGIN
kono
parents:
diff changeset
65 FAILED("EXCEPTION NOT RAISED BEFORE CALL -P1 (A)");
kono
parents:
diff changeset
66 END P1;
kono
parents:
diff changeset
67 BEGIN
kono
parents:
diff changeset
68 P1 (AST_5 (X_3));
kono
parents:
diff changeset
69 EXCEPTION
kono
parents:
diff changeset
70 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
71 NULL;
kono
parents:
diff changeset
72 WHEN OTHERS =>
kono
parents:
diff changeset
73 FAILED ("WRONG EXCEPTION RAISED -P1 (A)");
kono
parents:
diff changeset
74 END;
kono
parents:
diff changeset
75
kono
parents:
diff changeset
76 DECLARE
kono
parents:
diff changeset
77 TYPE ARRAY_TYPE IS ARRAY (INTEGER RANGE <>) OF BOOLEAN;
kono
parents:
diff changeset
78 TYPE A_ARRAY IS ACCESS ARRAY_TYPE;
kono
parents:
diff changeset
79 SUBTYPE A1_ARRAY IS A_ARRAY (1..IDENT_INT(3));
kono
parents:
diff changeset
80 TYPE A2_ARRAY IS NEW A_ARRAY (2..4);
kono
parents:
diff changeset
81 A0 : A1_ARRAY := NEW ARRAY_TYPE (1..3);
kono
parents:
diff changeset
82
kono
parents:
diff changeset
83 PROCEDURE P2 (X : IN OUT A2_ARRAY) IS
kono
parents:
diff changeset
84 BEGIN
kono
parents:
diff changeset
85 FAILED ("EXCEPTION NOT RAISED BEFORE CALL -P2 (A)");
kono
parents:
diff changeset
86 END P2;
kono
parents:
diff changeset
87 BEGIN
kono
parents:
diff changeset
88 P2 (A2_ARRAY (A0));
kono
parents:
diff changeset
89 EXCEPTION
kono
parents:
diff changeset
90 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
91 NULL;
kono
parents:
diff changeset
92 WHEN OTHERS =>
kono
parents:
diff changeset
93 FAILED ("WRONG EXCEPTION RAISED -P2 (A)");
kono
parents:
diff changeset
94 END;
kono
parents:
diff changeset
95
kono
parents:
diff changeset
96 DECLARE
kono
parents:
diff changeset
97 TYPE SUBINT IS RANGE 0..8;
kono
parents:
diff changeset
98 TYPE REC1 (DISC : SUBINT := 8) IS
kono
parents:
diff changeset
99 RECORD
kono
parents:
diff changeset
100 FIELD : SUBINT := DISC;
kono
parents:
diff changeset
101 END RECORD;
kono
parents:
diff changeset
102 TYPE A1_REC IS ACCESS REC1;
kono
parents:
diff changeset
103 TYPE A2_REC IS NEW A1_REC(3);
kono
parents:
diff changeset
104 A0 : A1_REC := NEW REC1(4);
kono
parents:
diff changeset
105
kono
parents:
diff changeset
106 PROCEDURE P3 (X : IN OUT A2_REC) IS
kono
parents:
diff changeset
107 BEGIN
kono
parents:
diff changeset
108 FAILED ("EXCEPTION NOT RAISED BEFORE CALL " &
kono
parents:
diff changeset
109 "-P3 (A)");
kono
parents:
diff changeset
110 END P3;
kono
parents:
diff changeset
111
kono
parents:
diff changeset
112 BEGIN
kono
parents:
diff changeset
113 P3 (A2_REC (A0));
kono
parents:
diff changeset
114 EXCEPTION
kono
parents:
diff changeset
115 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
116 NULL;
kono
parents:
diff changeset
117 WHEN OTHERS =>
kono
parents:
diff changeset
118 FAILED ("WRONG EXCEPTION RAISED -P3 (A)");
kono
parents:
diff changeset
119 END;
kono
parents:
diff changeset
120
kono
parents:
diff changeset
121 END;
kono
parents:
diff changeset
122
kono
parents:
diff changeset
123
kono
parents:
diff changeset
124 BEGIN
kono
parents:
diff changeset
125 DECLARE
kono
parents:
diff changeset
126 TYPE AST IS ACCESS STRING;
kono
parents:
diff changeset
127 SUBTYPE AST_3 IS AST(IDENT_INT(1)..IDENT_INT(3));
kono
parents:
diff changeset
128 X_3 : AST_3 := NEW STRING'(1..IDENT_INT(3) => 'A');
kono
parents:
diff changeset
129 CALLED : BOOLEAN := FALSE;
kono
parents:
diff changeset
130
kono
parents:
diff changeset
131 PROCEDURE P1 (X : IN OUT AST) IS
kono
parents:
diff changeset
132 BEGIN
kono
parents:
diff changeset
133 CALLED := TRUE;
kono
parents:
diff changeset
134 X := NEW STRING'(3..5 => 'C');
kono
parents:
diff changeset
135 END P1;
kono
parents:
diff changeset
136 BEGIN
kono
parents:
diff changeset
137 P1 (AST (X_3));
kono
parents:
diff changeset
138 IF X_3.ALL = STRING'(1 .. 3 => 'A') THEN
kono
parents:
diff changeset
139 FAILED ("EXCEPTION NOT RAISED AFTER CALL -P1 (B1)");
kono
parents:
diff changeset
140 ELSE
kono
parents:
diff changeset
141 FAILED ("EXCEPTION NOT RAISED AFTER CALL -P1 (B2)");
kono
parents:
diff changeset
142 END IF;
kono
parents:
diff changeset
143 EXCEPTION
kono
parents:
diff changeset
144 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
145 IF NOT CALLED THEN
kono
parents:
diff changeset
146 FAILED ("EXCEPTION RAISED BEFORE CALL" &
kono
parents:
diff changeset
147 "-P1 (B)");
kono
parents:
diff changeset
148 END IF;
kono
parents:
diff changeset
149 WHEN OTHERS =>
kono
parents:
diff changeset
150 FAILED ("WRONG EXCEPTION RAISED -P1 (B)");
kono
parents:
diff changeset
151 END;
kono
parents:
diff changeset
152
kono
parents:
diff changeset
153 DECLARE
kono
parents:
diff changeset
154 TYPE ARRAY_TYPE IS ARRAY (INTEGER RANGE <>) OF BOOLEAN;
kono
parents:
diff changeset
155 TYPE A_ARRAY IS ACCESS ARRAY_TYPE;
kono
parents:
diff changeset
156 SUBTYPE A1_ARRAY IS A_ARRAY (1..IDENT_INT(3));
kono
parents:
diff changeset
157 A0 : A1_ARRAY := NEW ARRAY_TYPE'(1..3 => TRUE);
kono
parents:
diff changeset
158 CALLED : BOOLEAN := FALSE;
kono
parents:
diff changeset
159
kono
parents:
diff changeset
160 PROCEDURE P2 (X : IN OUT A_ARRAY) IS
kono
parents:
diff changeset
161 BEGIN
kono
parents:
diff changeset
162 CALLED := TRUE;
kono
parents:
diff changeset
163 X := NEW ARRAY_TYPE'(2..4 => FALSE);
kono
parents:
diff changeset
164 END P2;
kono
parents:
diff changeset
165 BEGIN
kono
parents:
diff changeset
166 P2 (A_ARRAY (A0));
kono
parents:
diff changeset
167 IF A0.ALL = ARRAY_TYPE'(1 .. 3 => TRUE) THEN
kono
parents:
diff changeset
168 FAILED ("EXCEPTION NOT RAISED AFTER CALL -P2 (B1)");
kono
parents:
diff changeset
169 ELSE
kono
parents:
diff changeset
170 FAILED ("EXCEPTION NOT RAISED AFTER CALL -P2 (B2)");
kono
parents:
diff changeset
171 END IF;
kono
parents:
diff changeset
172 EXCEPTION
kono
parents:
diff changeset
173 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
174 IF NOT CALLED THEN
kono
parents:
diff changeset
175 FAILED ("EXCEPTION RAISED BEFORE CALL" &
kono
parents:
diff changeset
176 "-P1 (B)");
kono
parents:
diff changeset
177 END IF;
kono
parents:
diff changeset
178 WHEN OTHERS =>
kono
parents:
diff changeset
179 FAILED ("WRONG EXCEPTION RAISED -P2 (B)");
kono
parents:
diff changeset
180 END;
kono
parents:
diff changeset
181
kono
parents:
diff changeset
182 DECLARE
kono
parents:
diff changeset
183 TYPE SUBINT IS RANGE 0..8;
kono
parents:
diff changeset
184 TYPE REC1 (DISC : SUBINT := 8) IS
kono
parents:
diff changeset
185 RECORD
kono
parents:
diff changeset
186 FIELD : SUBINT := DISC;
kono
parents:
diff changeset
187 END RECORD;
kono
parents:
diff changeset
188 TYPE A1_REC IS ACCESS REC1;
kono
parents:
diff changeset
189 TYPE A2_REC IS NEW A1_REC;
kono
parents:
diff changeset
190 A0 : A1_REC(4) := NEW REC1(4);
kono
parents:
diff changeset
191 CALLED : BOOLEAN := FALSE;
kono
parents:
diff changeset
192
kono
parents:
diff changeset
193 PROCEDURE P3 (X : IN OUT A2_REC) IS
kono
parents:
diff changeset
194 BEGIN
kono
parents:
diff changeset
195 CALLED := TRUE;
kono
parents:
diff changeset
196 X := NEW REC1;
kono
parents:
diff changeset
197 END P3;
kono
parents:
diff changeset
198
kono
parents:
diff changeset
199 BEGIN
kono
parents:
diff changeset
200 P3 (A2_REC (A0));
kono
parents:
diff changeset
201 IF A0.ALL = REC1'(4,4) THEN
kono
parents:
diff changeset
202 FAILED ("EXCEPTION NOT RAISED AFTER CALL -P3 (B1)");
kono
parents:
diff changeset
203 ELSE
kono
parents:
diff changeset
204 FAILED ("EXCEPTION NOT RAISED AFTER CALL -P3 (B2)");
kono
parents:
diff changeset
205 END IF;
kono
parents:
diff changeset
206 EXCEPTION
kono
parents:
diff changeset
207 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
208 IF NOT CALLED THEN
kono
parents:
diff changeset
209 FAILED ("EXCEPTION RAISED BEFORE CALL" &
kono
parents:
diff changeset
210 "-P1 (B)");
kono
parents:
diff changeset
211 END IF;
kono
parents:
diff changeset
212 WHEN OTHERS =>
kono
parents:
diff changeset
213 FAILED ("WRONG EXCEPTION RAISED -P3 (B)");
kono
parents:
diff changeset
214 END;
kono
parents:
diff changeset
215
kono
parents:
diff changeset
216 END;
kono
parents:
diff changeset
217
kono
parents:
diff changeset
218 RESULT;
kono
parents:
diff changeset
219 END C64103E;