annotate gcc/testsuite/ada/acats/tests/c3/c34005c.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 -- C34005C.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 -- FOR DERIVED ONE-DIMENSIONAL ARRAY TYPES WHOSE COMPONENT TYPE IS A
kono
parents:
diff changeset
27 -- NON-LIMITED, NON-DISCRETE TYPE:
kono
parents:
diff changeset
28 -- CHECK THAT ALL VALUES OF THE PARENT (BASE) TYPE ARE PRESENT FOR
kono
parents:
diff changeset
29 -- THE DERIVED (BASE) TYPE WHEN THE DERIVED TYPE DEFINITION IS
kono
parents:
diff changeset
30 -- CONSTRAINED.
kono
parents:
diff changeset
31 -- CHECK THAT ANY CONSTRAINT IMPOSED ON THE PARENT SUBTYPE IS ALSO
kono
parents:
diff changeset
32 -- IMPOSED ON THE DERIVED SUBTYPE.
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 -- HISTORY:
kono
parents:
diff changeset
35 -- JRK 9/10/86 CREATED ORIGINAL TEST.
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 WITH REPORT; USE REPORT;
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 PROCEDURE C34005C IS
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 SUBTYPE COMPONENT IS FLOAT;
kono
parents:
diff changeset
42
kono
parents:
diff changeset
43 PACKAGE PKG IS
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 FIRST : CONSTANT := 0;
kono
parents:
diff changeset
46 LAST : CONSTANT := 100;
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 SUBTYPE INDEX IS INTEGER RANGE FIRST .. LAST;
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 TYPE PARENT IS ARRAY (INDEX RANGE <>) OF COMPONENT;
kono
parents:
diff changeset
51
kono
parents:
diff changeset
52 FUNCTION CREATE ( F, L : INDEX;
kono
parents:
diff changeset
53 C : COMPONENT;
kono
parents:
diff changeset
54 DUMMY : PARENT -- TO RESOLVE OVERLOADING.
kono
parents:
diff changeset
55 ) RETURN PARENT;
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 END PKG;
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 USE PKG;
kono
parents:
diff changeset
60
kono
parents:
diff changeset
61 TYPE T IS NEW PARENT (IDENT_INT (5) .. IDENT_INT (7));
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 SUBTYPE SUBPARENT IS PARENT (5 .. 7);
kono
parents:
diff changeset
64
kono
parents:
diff changeset
65 TYPE S IS NEW SUBPARENT;
kono
parents:
diff changeset
66
kono
parents:
diff changeset
67 X : T := (OTHERS => 2.0);
kono
parents:
diff changeset
68 Y : S := (OTHERS => 2.0);
kono
parents:
diff changeset
69
kono
parents:
diff changeset
70 PACKAGE BODY PKG IS
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72 FUNCTION CREATE
kono
parents:
diff changeset
73 ( F, L : INDEX;
kono
parents:
diff changeset
74 C : COMPONENT;
kono
parents:
diff changeset
75 DUMMY : PARENT
kono
parents:
diff changeset
76 ) RETURN PARENT
kono
parents:
diff changeset
77 IS
kono
parents:
diff changeset
78 A : PARENT (F .. L);
kono
parents:
diff changeset
79 B : COMPONENT := C;
kono
parents:
diff changeset
80 BEGIN
kono
parents:
diff changeset
81 FOR I IN F .. L LOOP
kono
parents:
diff changeset
82 A (I) := B;
kono
parents:
diff changeset
83 B := B + 1.0;
kono
parents:
diff changeset
84 END LOOP;
kono
parents:
diff changeset
85 RETURN A;
kono
parents:
diff changeset
86 END CREATE;
kono
parents:
diff changeset
87
kono
parents:
diff changeset
88 END PKG;
kono
parents:
diff changeset
89
kono
parents:
diff changeset
90 BEGIN
kono
parents:
diff changeset
91 TEST ("C34005C", "CHECK THAT ALL VALUES OF THE PARENT (BASE) " &
kono
parents:
diff changeset
92 "TYPE ARE PRESENT FOR THE DERIVED (BASE) TYPE " &
kono
parents:
diff changeset
93 "WHEN THE DERIVED TYPE DEFINITION IS " &
kono
parents:
diff changeset
94 "CONSTRAINED. ALSO CHECK THAT ANY CONSTRAINT " &
kono
parents:
diff changeset
95 "IMPOSED ON THE PARENT SUBTYPE IS ALSO IMPOSED " &
kono
parents:
diff changeset
96 "ON THE DERIVED SUBTYPE. CHECK FOR DERIVED " &
kono
parents:
diff changeset
97 "ONE-DIMENSIONAL ARRAY TYPES WHOSE COMPONENT " &
kono
parents:
diff changeset
98 "TYPE IS A NON-LIMITED, NON-DISCRETE TYPE");
kono
parents:
diff changeset
99
kono
parents:
diff changeset
100 -- CHECK THAT BASE TYPE VALUES NOT IN THE SUBTYPE ARE PRESENT.
kono
parents:
diff changeset
101
kono
parents:
diff changeset
102 BEGIN
kono
parents:
diff changeset
103 IF CREATE (2, 3, 4.0, X) /= (4.0, 5.0) OR
kono
parents:
diff changeset
104 CREATE (2, 3, 4.0, Y) /= (4.0, 5.0) THEN
kono
parents:
diff changeset
105 FAILED ("CAN'T CREATE BASE TYPE VALUES OUTSIDE THE " &
kono
parents:
diff changeset
106 "SUBTYPE");
kono
parents:
diff changeset
107 END IF;
kono
parents:
diff changeset
108 EXCEPTION
kono
parents:
diff changeset
109 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
110 FAILED ("CALL TO CREATE RAISED CONSTRAINT_ERROR");
kono
parents:
diff changeset
111 WHEN OTHERS =>
kono
parents:
diff changeset
112 FAILED ("CALL TO CREATE RAISED EXCEPTION");
kono
parents:
diff changeset
113 END;
kono
parents:
diff changeset
114
kono
parents:
diff changeset
115 IF X & (3.0, 4.0) /= (2.0, 2.0, 2.0, 3.0, 4.0) OR
kono
parents:
diff changeset
116 Y & (3.0, 4.0) /= (2.0, 2.0, 2.0, 3.0, 4.0) THEN
kono
parents:
diff changeset
117 FAILED ("INCORRECT &");
kono
parents:
diff changeset
118 END IF;
kono
parents:
diff changeset
119
kono
parents:
diff changeset
120 -- CHECK THE DERIVED SUBTYPE CONSTRAINT.
kono
parents:
diff changeset
121
kono
parents:
diff changeset
122 IF T'FIRST /= 5 OR T'LAST /= 7 OR
kono
parents:
diff changeset
123 S'FIRST /= 5 OR S'LAST /= 7 THEN
kono
parents:
diff changeset
124 FAILED ("INCORRECT 'FIRST OR 'LAST");
kono
parents:
diff changeset
125 END IF;
kono
parents:
diff changeset
126
kono
parents:
diff changeset
127 BEGIN
kono
parents:
diff changeset
128 X := (1.0, 2.0, 3.0);
kono
parents:
diff changeset
129 Y := (1.0, 2.0, 3.0);
kono
parents:
diff changeset
130 IF PARENT (X) /= PARENT (Y) THEN -- USE X AND Y.
kono
parents:
diff changeset
131 FAILED ("INCORRECT CONVERSION TO PARENT");
kono
parents:
diff changeset
132 END IF;
kono
parents:
diff changeset
133 EXCEPTION
kono
parents:
diff changeset
134 WHEN OTHERS =>
kono
parents:
diff changeset
135 FAILED ("EXCEPTION RAISED BY OK ASSIGNMENT");
kono
parents:
diff changeset
136 END;
kono
parents:
diff changeset
137
kono
parents:
diff changeset
138 BEGIN
kono
parents:
diff changeset
139 X := (1.0, 2.0);
kono
parents:
diff changeset
140 FAILED ("CONSTRAINT_ERROR NOT RAISED -- X := (1.0, 2.0)");
kono
parents:
diff changeset
141 IF X = (1.0, 2.0) THEN -- USE X.
kono
parents:
diff changeset
142 COMMENT ("X ALTERED -- X := (1.0, 2.0)");
kono
parents:
diff changeset
143 END IF;
kono
parents:
diff changeset
144 EXCEPTION
kono
parents:
diff changeset
145 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
146 NULL;
kono
parents:
diff changeset
147 WHEN OTHERS =>
kono
parents:
diff changeset
148 FAILED ("WRONG EXCEPTION RAISED -- X := (1.0, 2.0)");
kono
parents:
diff changeset
149 END;
kono
parents:
diff changeset
150
kono
parents:
diff changeset
151 BEGIN
kono
parents:
diff changeset
152 X := (1.0, 2.0, 3.0, 4.0);
kono
parents:
diff changeset
153 FAILED ("CONSTRAINT_ERROR NOT RAISED -- " &
kono
parents:
diff changeset
154 "X := (1.0, 2.0, 3.0, 4.0)");
kono
parents:
diff changeset
155 IF X = (1.0, 2.0, 3.0, 4.0) THEN -- USE X.
kono
parents:
diff changeset
156 COMMENT ("X ALTERED -- X := (1.0, 2.0, 3.0, 4.0)");
kono
parents:
diff changeset
157 END IF;
kono
parents:
diff changeset
158 EXCEPTION
kono
parents:
diff changeset
159 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
160 NULL;
kono
parents:
diff changeset
161 WHEN OTHERS =>
kono
parents:
diff changeset
162 FAILED ("WRONG EXCEPTION RAISED -- " &
kono
parents:
diff changeset
163 "X := (1.0, 2.0, 3.0, 4.0)");
kono
parents:
diff changeset
164 END;
kono
parents:
diff changeset
165
kono
parents:
diff changeset
166 BEGIN
kono
parents:
diff changeset
167 Y := (1.0, 2.0);
kono
parents:
diff changeset
168 FAILED ("CONSTRAINT_ERROR NOT RAISED -- Y := (1.0, 2.0)");
kono
parents:
diff changeset
169 IF Y = (1.0, 2.0) THEN -- USE Y.
kono
parents:
diff changeset
170 COMMENT ("Y ALTERED -- Y := (1.0, 2.0)");
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 NULL;
kono
parents:
diff changeset
175 WHEN OTHERS =>
kono
parents:
diff changeset
176 FAILED ("WRONG EXCEPTION RAISED -- Y := (1.0, 2.0)");
kono
parents:
diff changeset
177 END;
kono
parents:
diff changeset
178
kono
parents:
diff changeset
179 BEGIN
kono
parents:
diff changeset
180 Y := (1.0, 2.0, 3.0, 4.0);
kono
parents:
diff changeset
181 FAILED ("CONSTRAINT_ERROR NOT RAISED -- " &
kono
parents:
diff changeset
182 "Y := (1.0, 2.0, 3.0, 4.0)");
kono
parents:
diff changeset
183 IF Y = (1.0, 2.0, 3.0, 4.0) THEN -- USE Y.
kono
parents:
diff changeset
184 COMMENT ("Y ALTERED -- Y := (1.0, 2.0, 3.0, 4.0)");
kono
parents:
diff changeset
185 END IF;
kono
parents:
diff changeset
186 EXCEPTION
kono
parents:
diff changeset
187 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
188 NULL;
kono
parents:
diff changeset
189 WHEN OTHERS =>
kono
parents:
diff changeset
190 FAILED ("WRONG EXCEPTION RAISED -- " &
kono
parents:
diff changeset
191 "Y := (1.0, 2.0, 3.0, 4.0)");
kono
parents:
diff changeset
192 END;
kono
parents:
diff changeset
193
kono
parents:
diff changeset
194 RESULT;
kono
parents:
diff changeset
195 END C34005C;