Mercurial > hg > CbC > CbC_gcc
comparison gcc/testsuite/ada/acats/tests/c4/c43204c.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 -- C43204C.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 AN ARRAY AGGREGATE WITH AN OTHERS CHOICE CAN APPEAR | |
27 -- (AND BOUNDS ARE DETERMINED CORRECTLY) AS AN ACTUAL PARAMETER OF | |
28 -- A GENERIC INSTANTIATION WHEN THE GENERIC FORMAL PARAMETER IS | |
29 -- CONSTRAINED. | |
30 | |
31 -- HISTORY: | |
32 -- JET 08/15/88 CREATED ORIGINAL TEST. | |
33 | |
34 WITH REPORT; USE REPORT; | |
35 PROCEDURE C43204C IS | |
36 | |
37 TYPE ARR10 IS ARRAY(IDENT_INT(1)..IDENT_INT(0)) OF INTEGER; | |
38 TYPE ARR11 IS ARRAY(INTEGER RANGE -3..3) OF INTEGER; | |
39 TYPE ARR12 IS ARRAY(IDENT_INT(-3)..IDENT_INT(3)) OF INTEGER; | |
40 | |
41 TYPE ARR20 IS ARRAY(IDENT_INT(1)..IDENT_INT(0), | |
42 IDENT_INT(0)..IDENT_INT(-1)) OF INTEGER; | |
43 TYPE ARR21 IS ARRAY(INTEGER RANGE -1..1, | |
44 INTEGER RANGE -1..1) OF INTEGER; | |
45 TYPE ARR22 IS ARRAY(IDENT_INT(-1)..IDENT_INT(1), | |
46 IDENT_INT(-1)..IDENT_INT(1)) OF INTEGER; | |
47 TYPE ARR23 IS ARRAY(INTEGER'(-1)..1, | |
48 IDENT_INT(-1)..IDENT_INT(1)) OF INTEGER; | |
49 | |
50 GENERIC | |
51 A : ARR10; | |
52 PROCEDURE GPROC10; | |
53 | |
54 GENERIC | |
55 A : ARR11; | |
56 PROCEDURE GPROC11; | |
57 | |
58 GENERIC | |
59 A : ARR12; | |
60 PROCEDURE GPROC12; | |
61 | |
62 GENERIC | |
63 A : ARR20; | |
64 PROCEDURE GPROC20; | |
65 | |
66 GENERIC | |
67 A : ARR21; | |
68 PROCEDURE GPROC21 (C : INTEGER); | |
69 | |
70 GENERIC | |
71 A : ARR22; | |
72 PROCEDURE GPROC22; | |
73 | |
74 GENERIC | |
75 A : ARR23; | |
76 PROCEDURE GPROC23; | |
77 | |
78 PROCEDURE GPROC10 IS | |
79 BEGIN | |
80 IF A'LENGTH /= IDENT_INT(0) THEN | |
81 FAILED ("PROC10 ARRAY IS NOT NULL"); | |
82 END IF; | |
83 END GPROC10; | |
84 | |
85 PROCEDURE GPROC11 IS | |
86 BEGIN | |
87 IF A'LENGTH /= IDENT_INT(7) OR | |
88 A'FIRST /= IDENT_INT(-3) OR | |
89 A'LAST /= IDENT_INT(3) THEN | |
90 FAILED ("INCORRECT LENGTH IN PROC11"); | |
91 END IF; | |
92 | |
93 FOR I IN IDENT_INT(-3)..IDENT_INT(3) LOOP | |
94 IF IDENT_INT(A(I)) /= 1 THEN | |
95 FAILED ("INCORRECT VALUE OF COMPONENT " & | |
96 INTEGER'IMAGE(I) & ", PROC11"); | |
97 END IF; | |
98 END LOOP; | |
99 END GPROC11; | |
100 | |
101 PROCEDURE GPROC12 IS | |
102 BEGIN | |
103 IF A'LENGTH /= IDENT_INT(7) THEN | |
104 FAILED ("INCORRECT LENGTH IN PROC12"); | |
105 END IF; | |
106 | |
107 FOR I IN IDENT_INT(-3)..IDENT_INT(3) LOOP | |
108 IF IDENT_INT(A(I)) /= 2 THEN | |
109 FAILED ("INCORRECT VALUE OF COMPONENT " & | |
110 INTEGER'IMAGE(I) & ", PROC12"); | |
111 END IF; | |
112 END LOOP; | |
113 END GPROC12; | |
114 | |
115 PROCEDURE GPROC20 IS | |
116 BEGIN | |
117 IF A'LENGTH(1) /= IDENT_INT(0) OR | |
118 A'LENGTH(2) /= IDENT_INT(0) THEN | |
119 FAILED ("GPROC20 ARRAY IS NOT NULL"); | |
120 END IF; | |
121 END GPROC20; | |
122 | |
123 PROCEDURE GPROC21 (C : INTEGER) IS | |
124 BEGIN | |
125 FOR I IN INTEGER'(-1)..1 LOOP | |
126 FOR J IN INTEGER'(-1)..1 LOOP | |
127 IF IDENT_INT(A(I,J)) /= C THEN | |
128 FAILED ("INCORRECT VALUE OF COMPONENT (" & | |
129 INTEGER'IMAGE(I) & "," & | |
130 INTEGER'IMAGE(J) & "), GPROC21 CALL " & | |
131 "NUMBER" & INTEGER'IMAGE(C)); | |
132 END IF; | |
133 END LOOP; | |
134 END LOOP; | |
135 END GPROC21; | |
136 | |
137 PROCEDURE GPROC22 IS | |
138 BEGIN | |
139 FOR I IN INTEGER'(-1)..1 LOOP | |
140 FOR J IN INTEGER'(-1)..1 LOOP | |
141 IF IDENT_INT(A(I,J)) /= 3 THEN | |
142 FAILED ("INCORRECT VALUE OF COMPONENT (" & | |
143 INTEGER'IMAGE(I) & "," & | |
144 INTEGER'IMAGE(J) & "), GPROC22"); | |
145 END IF; | |
146 END LOOP; | |
147 END LOOP; | |
148 END GPROC22; | |
149 | |
150 PROCEDURE GPROC23 IS | |
151 BEGIN | |
152 FOR I IN INTEGER'(-1)..1 LOOP | |
153 FOR J IN INTEGER'(-1)..1 LOOP | |
154 IF IDENT_INT(A(I,J)) /= 4 THEN | |
155 FAILED ("INCORRECT VALUE OF COMPONENT (" & | |
156 INTEGER'IMAGE(I) & "," & | |
157 INTEGER'IMAGE(J) & "), GPROC23"); | |
158 END IF; | |
159 END LOOP; | |
160 END LOOP; | |
161 END GPROC23; | |
162 | |
163 PROCEDURE PROC11 IS NEW GPROC11((1,1,1, OTHERS => 1)); | |
164 PROCEDURE PROC12 IS NEW GPROC12((OTHERS => 2)); | |
165 PROCEDURE PROC10 IS NEW GPROC10((OTHERS => 3)); | |
166 | |
167 PROCEDURE PROC21 IS NEW GPROC21(((1,1,1), OTHERS => (1,1,1))); | |
168 PROCEDURE PROC22 IS NEW GPROC21(((2,OTHERS => 2), (2,OTHERS => 2), | |
169 (2,2,OTHERS => 2))); | |
170 PROCEDURE PROC23 IS NEW GPROC22((OTHERS => (OTHERS => 3))); | |
171 PROCEDURE PROC24 IS NEW GPROC23((OTHERS => (4,4,4))); | |
172 PROCEDURE PROC20 IS NEW GPROC20((OTHERS => (OTHERS => 5))); | |
173 | |
174 BEGIN | |
175 TEST ("C43204C", "CHECK THAT AN ARRAY AGGREGATE WITH AN OTHERS " & | |
176 "CHOICE CAN APPEAR (AND BOUNDS ARE DETERMINED " & | |
177 "CORRECTLY) AS AN ACTUAL PARAMETER OF A " & | |
178 "SUBPROGRAM CALL WHEN THE FORMAL PARAMETER IS " & | |
179 "CONSTRAINED"); | |
180 | |
181 PROC11; | |
182 PROC12; | |
183 PROC10; | |
184 | |
185 PROC21(1); | |
186 PROC22(2); | |
187 PROC23; | |
188 PROC24; | |
189 PROC20; | |
190 | |
191 RESULT; | |
192 END C43204C; |