comparison gcc/testsuite/ada/acats/tests/c4/c48009g.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 -- C48009G.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 -- FOR ALLOCATORS OF THE FORM "NEW T'(X)", CHECK THAT
27 -- CONSTRAINT_ERROR IS RAISED IF T IS A CONSTRAINED ACCESS
28 -- TYPE AND THE OBJECT DESIGNATED BY X DOES NOT HAVE DISCRIMINANTS
29 -- OR INDEX BOUNDS THAT EQUAL THE CORRESPONDING VALUES FOR T.
30
31 -- HISTORY:
32 -- EG 08/30/84 CREATED ORIGINAL TEST.
33 -- JET 01/05/87 UPDATED HEADER FORMAT AND ADDED CODE TO PREVENT
34 -- OPTIMIZATION.
35
36 WITH REPORT;
37
38 PROCEDURE C48009G IS
39
40 USE REPORT;
41
42 GENERIC
43 TYPE G_TYPE IS PRIVATE;
44 FUNCTION EQUAL_G (X : G_TYPE; Y : G_TYPE) RETURN BOOLEAN;
45
46 FUNCTION EQUAL_G (X : G_TYPE; Y : G_TYPE) RETURN BOOLEAN IS
47 BEGIN
48 IF (IDENT_INT(3) = 3) AND (X = Y) THEN
49 RETURN TRUE;
50 ELSE
51 RETURN FALSE;
52 END IF;
53 END EQUAL_G;
54
55 BEGIN
56
57 TEST("C48009G","FOR ALLOCATORS OF THE FORM 'NEW T'(X)', CHECK " &
58 "THAT CONSTRAINT_ERROR IS RAISED WHEN " &
59 "APPROPRIATE - CONSTRAINED ACCESS TYPE");
60
61 DECLARE
62
63 TYPE INT IS RANGE 1 .. 5;
64
65 TYPE UR(A : INT) IS
66 RECORD
67 B : INTEGER;
68 END RECORD;
69 TYPE UA IS ARRAY(INT RANGE <>) OF INTEGER;
70
71 PACKAGE P IS
72 TYPE UP(A, B : INT) IS PRIVATE;
73 TYPE UL(A, B : INT) IS LIMITED PRIVATE;
74 CONS_UP : CONSTANT UP;
75 PRIVATE
76 TYPE UP(A, B : INT) IS
77 RECORD
78 C : INTEGER;
79 END RECORD;
80 TYPE UL(A, B : INT) IS
81 RECORD
82 C : INTEGER;
83 END RECORD;
84 CONS_UP : CONSTANT UP := (2, 2, (IDENT_INT(3)));
85 END P;
86
87 TYPE A_UR IS ACCESS UR;
88 TYPE A_UA IS ACCESS UA;
89 TYPE A_UP IS ACCESS P.UP;
90 TYPE A_UL IS ACCESS P.UL;
91
92 SUBTYPE CA_UR IS A_UR(2);
93 SUBTYPE CA_UA IS A_UA(2 .. 3);
94 SUBTYPE CA_UP IS A_UP(3, 2);
95 SUBTYPE CA_UL IS A_UL(2, 4);
96
97 TYPE A_CA_UR IS ACCESS CA_UR;
98 TYPE A_CA_UA IS ACCESS CA_UA;
99 TYPE A_CA_UP IS ACCESS CA_UP;
100 TYPE A_CA_UL IS ACCESS CA_UL;
101
102 V_A_CA_UR : A_CA_UR;
103 V_A_CA_UA : A_CA_UA;
104 V_A_CA_UP : A_CA_UP;
105 V_A_CA_UL : A_CA_UL;
106
107 FUNCTION EQUAL IS NEW EQUAL_G(A_CA_UR);
108 FUNCTION EQUAL IS NEW EQUAL_G(A_CA_UA);
109 FUNCTION EQUAL IS NEW EQUAL_G(A_CA_UP);
110 FUNCTION EQUAL IS NEW EQUAL_G(A_CA_UL);
111
112 BEGIN
113
114 BEGIN
115 V_A_CA_UR := NEW CA_UR'(NEW UR'(1,(IDENT_INT(2))));
116
117 IF EQUAL (V_A_CA_UR, V_A_CA_UR) THEN
118 FAILED ("NO EXCEPTION RAISED - UR");
119 END IF;
120
121 EXCEPTION
122 WHEN CONSTRAINT_ERROR =>
123 NULL;
124 WHEN OTHERS =>
125 FAILED ("WRONG EXCEPTION RAISED - UR");
126 END;
127
128 BEGIN
129 V_A_CA_UA := NEW CA_UA'(NEW UA'(1 => 2,
130 2 => IDENT_INT(3)));
131
132 IF EQUAL (V_A_CA_UA, V_A_CA_UA) THEN
133 FAILED ("NO EXCEPTION RAISED - UA");
134 END IF;
135
136 EXCEPTION
137 WHEN CONSTRAINT_ERROR =>
138 NULL;
139 WHEN OTHERS =>
140 FAILED ("WRONG EXCEPTION RAISED - UA");
141 END;
142
143 BEGIN
144 V_A_CA_UP := NEW CA_UP'(NEW P.UP'(P.CONS_UP));
145
146 IF EQUAL (V_A_CA_UP, V_A_CA_UP) THEN
147 FAILED ("NO EXCEPTION RAISED - UP");
148 END IF;
149
150 EXCEPTION
151 WHEN CONSTRAINT_ERROR =>
152 NULL;
153 WHEN OTHERS =>
154 FAILED ("WRONG EXCEPTION RAISED - UP");
155 END;
156
157 BEGIN
158 V_A_CA_UR := NEW CA_UR'(NULL);
159
160 IF NOT EQUAL (V_A_CA_UR, V_A_CA_UR) THEN
161 COMMENT ("NO EXCEPTION RAISED - UR");
162 END IF;
163
164 EXCEPTION
165 WHEN OTHERS =>
166 FAILED ("EXCEPTION RAISED - UR");
167 END;
168
169 BEGIN
170 V_A_CA_UA := NEW CA_UA'(NULL);
171
172 IF NOT EQUAL (V_A_CA_UA, V_A_CA_UA) THEN
173 COMMENT ("NO EXCEPTION RAISED - UA");
174 END IF;
175
176 EXCEPTION
177 WHEN OTHERS =>
178 FAILED ("EXCEPTION RAISED - UA");
179 END;
180
181 BEGIN
182 V_A_CA_UP := NEW CA_UP'(NULL);
183
184 IF NOT EQUAL (V_A_CA_UP, V_A_CA_UP) THEN
185 COMMENT ("NO EXCEPTION RAISED - UP");
186 END IF;
187
188 EXCEPTION
189 WHEN OTHERS =>
190 FAILED ("EXCEPTION RAISED - UP");
191 END;
192
193 BEGIN
194 V_A_CA_UL := NEW CA_UL'(NULL);
195
196 IF NOT EQUAL (V_A_CA_UL, V_A_CA_UL) THEN
197 COMMENT ("NO EXCEPTION RAISED - UL");
198 END IF;
199
200 EXCEPTION
201 WHEN OTHERS =>
202 FAILED ("EXCEPTION RAISED - UL");
203 END;
204
205 END;
206
207 RESULT;
208
209 END C48009G;