Mercurial > hg > CbC > CbC_gcc
comparison 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 |
comparison
equal
deleted
inserted
replaced
68:561a7518be6b | 111:04ced10e8804 |
---|---|
1 -- C64103E.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 -- OBJECTIVE: | |
26 -- CHECK THAT, FOR IN-OUT PARAMETERS OF AN ACCESS TYPE, | |
27 -- CONSTRAINT_ERROR IS RAISED: | |
28 -- BEFORE A SUBPROGRAM CALL WHEN THE BOUNDS OR DISCRIMINANTS | |
29 -- OF THE ACTUAL DESIGNATED PARAMETER ARE DIFFERENT FROM | |
30 -- THOSE OF THE FORMAL DESIGNATED PARAMETER; | |
31 -- AFTER A SUBPROGRAM CALL WHEN THE BOUNDS OR DISCRIMINANTS | |
32 -- OF THE FORMAL DESIGNATED PARAMETER ARE DIFFERENT FROM | |
33 -- THOSE OF THE ACTUAL DESIGNATED PARAMETER. | |
34 | |
35 -- HISTORY: | |
36 -- CPP 07/23/84 CREATED ORIGINAL TEST. | |
37 -- VCL 10/27/87 MODIFIED THIS HEADER; ADDED STATEMENTS WHICH | |
38 -- REFERENCED THE ACTUAL PARAMETERS IN THE SECOND | |
39 -- SUBTEST. | |
40 | |
41 WITH REPORT; USE REPORT; | |
42 PROCEDURE C64103E IS | |
43 BEGIN | |
44 TEST ("C64103E", "FOR IN-OUT PARAMETERS OF AN ACCESS TYPE, " & | |
45 "CONSTRAINT_ERROR IS RAISED: BEFORE A " & | |
46 "SUBPROGRAM CALL WHEN THE BOUNDS OR " & | |
47 "DISCRIMINANTS OF THE ACTUAL DESIGNATED " & | |
48 "PARAMETER ARE DIFFERENT FROM THOSE OF THE " & | |
49 "FORMAL DESIGNATED PARAMETER; AFTER A " & | |
50 "SUBPROGRAM CALL WHEN THE BOUNDS OR " & | |
51 "DISCRIMINANTS OF THE FORMAL DESIGNATED " & | |
52 "PARAMETER ARE DIFFERENT FROM THOSE OF THE " & | |
53 "ACTUAL DESIGNATED PARAMETER"); | |
54 | |
55 | |
56 BEGIN | |
57 DECLARE | |
58 TYPE AST IS ACCESS STRING; | |
59 SUBTYPE AST_3 IS AST(1..3); | |
60 SUBTYPE AST_5 IS AST(3..5); | |
61 X_3 : AST_3 := NEW STRING(1..IDENT_INT(3)); | |
62 | |
63 PROCEDURE P1 (X : IN OUT AST_5) IS | |
64 BEGIN | |
65 FAILED("EXCEPTION NOT RAISED BEFORE CALL -P1 (A)"); | |
66 END P1; | |
67 BEGIN | |
68 P1 (AST_5 (X_3)); | |
69 EXCEPTION | |
70 WHEN CONSTRAINT_ERROR => | |
71 NULL; | |
72 WHEN OTHERS => | |
73 FAILED ("WRONG EXCEPTION RAISED -P1 (A)"); | |
74 END; | |
75 | |
76 DECLARE | |
77 TYPE ARRAY_TYPE IS ARRAY (INTEGER RANGE <>) OF BOOLEAN; | |
78 TYPE A_ARRAY IS ACCESS ARRAY_TYPE; | |
79 SUBTYPE A1_ARRAY IS A_ARRAY (1..IDENT_INT(3)); | |
80 TYPE A2_ARRAY IS NEW A_ARRAY (2..4); | |
81 A0 : A1_ARRAY := NEW ARRAY_TYPE (1..3); | |
82 | |
83 PROCEDURE P2 (X : IN OUT A2_ARRAY) IS | |
84 BEGIN | |
85 FAILED ("EXCEPTION NOT RAISED BEFORE CALL -P2 (A)"); | |
86 END P2; | |
87 BEGIN | |
88 P2 (A2_ARRAY (A0)); | |
89 EXCEPTION | |
90 WHEN CONSTRAINT_ERROR => | |
91 NULL; | |
92 WHEN OTHERS => | |
93 FAILED ("WRONG EXCEPTION RAISED -P2 (A)"); | |
94 END; | |
95 | |
96 DECLARE | |
97 TYPE SUBINT IS RANGE 0..8; | |
98 TYPE REC1 (DISC : SUBINT := 8) IS | |
99 RECORD | |
100 FIELD : SUBINT := DISC; | |
101 END RECORD; | |
102 TYPE A1_REC IS ACCESS REC1; | |
103 TYPE A2_REC IS NEW A1_REC(3); | |
104 A0 : A1_REC := NEW REC1(4); | |
105 | |
106 PROCEDURE P3 (X : IN OUT A2_REC) IS | |
107 BEGIN | |
108 FAILED ("EXCEPTION NOT RAISED BEFORE CALL " & | |
109 "-P3 (A)"); | |
110 END P3; | |
111 | |
112 BEGIN | |
113 P3 (A2_REC (A0)); | |
114 EXCEPTION | |
115 WHEN CONSTRAINT_ERROR => | |
116 NULL; | |
117 WHEN OTHERS => | |
118 FAILED ("WRONG EXCEPTION RAISED -P3 (A)"); | |
119 END; | |
120 | |
121 END; | |
122 | |
123 | |
124 BEGIN | |
125 DECLARE | |
126 TYPE AST IS ACCESS STRING; | |
127 SUBTYPE AST_3 IS AST(IDENT_INT(1)..IDENT_INT(3)); | |
128 X_3 : AST_3 := NEW STRING'(1..IDENT_INT(3) => 'A'); | |
129 CALLED : BOOLEAN := FALSE; | |
130 | |
131 PROCEDURE P1 (X : IN OUT AST) IS | |
132 BEGIN | |
133 CALLED := TRUE; | |
134 X := NEW STRING'(3..5 => 'C'); | |
135 END P1; | |
136 BEGIN | |
137 P1 (AST (X_3)); | |
138 IF X_3.ALL = STRING'(1 .. 3 => 'A') THEN | |
139 FAILED ("EXCEPTION NOT RAISED AFTER CALL -P1 (B1)"); | |
140 ELSE | |
141 FAILED ("EXCEPTION NOT RAISED AFTER CALL -P1 (B2)"); | |
142 END IF; | |
143 EXCEPTION | |
144 WHEN CONSTRAINT_ERROR => | |
145 IF NOT CALLED THEN | |
146 FAILED ("EXCEPTION RAISED BEFORE CALL" & | |
147 "-P1 (B)"); | |
148 END IF; | |
149 WHEN OTHERS => | |
150 FAILED ("WRONG EXCEPTION RAISED -P1 (B)"); | |
151 END; | |
152 | |
153 DECLARE | |
154 TYPE ARRAY_TYPE IS ARRAY (INTEGER RANGE <>) OF BOOLEAN; | |
155 TYPE A_ARRAY IS ACCESS ARRAY_TYPE; | |
156 SUBTYPE A1_ARRAY IS A_ARRAY (1..IDENT_INT(3)); | |
157 A0 : A1_ARRAY := NEW ARRAY_TYPE'(1..3 => TRUE); | |
158 CALLED : BOOLEAN := FALSE; | |
159 | |
160 PROCEDURE P2 (X : IN OUT A_ARRAY) IS | |
161 BEGIN | |
162 CALLED := TRUE; | |
163 X := NEW ARRAY_TYPE'(2..4 => FALSE); | |
164 END P2; | |
165 BEGIN | |
166 P2 (A_ARRAY (A0)); | |
167 IF A0.ALL = ARRAY_TYPE'(1 .. 3 => TRUE) THEN | |
168 FAILED ("EXCEPTION NOT RAISED AFTER CALL -P2 (B1)"); | |
169 ELSE | |
170 FAILED ("EXCEPTION NOT RAISED AFTER CALL -P2 (B2)"); | |
171 END IF; | |
172 EXCEPTION | |
173 WHEN CONSTRAINT_ERROR => | |
174 IF NOT CALLED THEN | |
175 FAILED ("EXCEPTION RAISED BEFORE CALL" & | |
176 "-P1 (B)"); | |
177 END IF; | |
178 WHEN OTHERS => | |
179 FAILED ("WRONG EXCEPTION RAISED -P2 (B)"); | |
180 END; | |
181 | |
182 DECLARE | |
183 TYPE SUBINT IS RANGE 0..8; | |
184 TYPE REC1 (DISC : SUBINT := 8) IS | |
185 RECORD | |
186 FIELD : SUBINT := DISC; | |
187 END RECORD; | |
188 TYPE A1_REC IS ACCESS REC1; | |
189 TYPE A2_REC IS NEW A1_REC; | |
190 A0 : A1_REC(4) := NEW REC1(4); | |
191 CALLED : BOOLEAN := FALSE; | |
192 | |
193 PROCEDURE P3 (X : IN OUT A2_REC) IS | |
194 BEGIN | |
195 CALLED := TRUE; | |
196 X := NEW REC1; | |
197 END P3; | |
198 | |
199 BEGIN | |
200 P3 (A2_REC (A0)); | |
201 IF A0.ALL = REC1'(4,4) THEN | |
202 FAILED ("EXCEPTION NOT RAISED AFTER CALL -P3 (B1)"); | |
203 ELSE | |
204 FAILED ("EXCEPTION NOT RAISED AFTER CALL -P3 (B2)"); | |
205 END IF; | |
206 EXCEPTION | |
207 WHEN CONSTRAINT_ERROR => | |
208 IF NOT CALLED THEN | |
209 FAILED ("EXCEPTION RAISED BEFORE CALL" & | |
210 "-P1 (B)"); | |
211 END IF; | |
212 WHEN OTHERS => | |
213 FAILED ("WRONG EXCEPTION RAISED -P3 (B)"); | |
214 END; | |
215 | |
216 END; | |
217 | |
218 RESULT; | |
219 END C64103E; |