Mercurial > hg > CbC > CbC_gcc
comparison gcc/testsuite/ada/acats/tests/c4/c45322a.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 -- C45322A.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 CONSTRAINT_ERROR IS RAISED IF | |
27 -- MACHINE_OVERFLOWS IS TRUE AND THE RESULT OF THE ADDITION OR | |
28 -- SUBTRACTION LIES OUTSIDE OF THE RANGE OF THE BASE TYPE. | |
29 | |
30 -- *** NOTE: This test has been modified since ACVC version 1.11 to -- 9X | |
31 -- *** remove incompatibilities associated with the transition -- 9X | |
32 -- *** to Ada 9X. -- 9X | |
33 | |
34 -- HISTORY: | |
35 -- NPL 09/01/90 CREATED ORIGINAL TEST. | |
36 -- LDC 10/09/90 CHANGED THE STYLE OF THE TEST TO THE STANDARD | |
37 -- ACVC FORMAT AND WRAPPED LINES WHICH WHERE LONGER | |
38 -- THAN 71 CHARACTERS. | |
39 -- JRL 03/30/93 REMOVED NUMERIC_ERROR FROM TEST. | |
40 | |
41 WITH REPORT; USE REPORT; | |
42 | |
43 PROCEDURE C45322A IS | |
44 | |
45 TYPE FLOAT5 IS DIGITS 5; | |
46 F5 : FLOAT5; | |
47 | |
48 FUNCTION IDENT (F : FLOAT5) RETURN FLOAT5 IS | |
49 BEGIN | |
50 RETURN F * FLOAT5(IDENT_INT(1)); | |
51 END IDENT; | |
52 | |
53 FUNCTION EQUAL (F,G : FLOAT5) RETURN BOOLEAN IS | |
54 BEGIN | |
55 RETURN F = G + FLOAT5(IDENT_INT(0)); | |
56 END EQUAL; | |
57 | |
58 BEGIN | |
59 TEST ("C45322A", "CHECK THAT CONSTRAINT_ERROR " & | |
60 "IS RAISED IF MACHINE_OVERFLOWS IS TRUE AND " & | |
61 "THE RESULT OF THE ADDITION OR SUBTRACTION " & | |
62 "LIES OUTSIDE OF THE RANGE OF THE BASE TYPE"); | |
63 | |
64 IF NOT FLOAT5'MACHINE_OVERFLOWS THEN | |
65 NOT_APPLICABLE("MACHINE_OVERFLOWS IS FALSE"); | |
66 ELSE | |
67 | |
68 BEGIN | |
69 F5 := IDENT(FLOAT5'BASE'LAST) + FLOAT5'BASE'LAST; | |
70 | |
71 FAILED("NO EXCEPTION RAISED BY LARGE '+'"); | |
72 | |
73 IF NOT EQUAL(F5, F5) THEN | |
74 COMMENT("DON'T OPTIMIZE F5"); | |
75 END IF; | |
76 EXCEPTION | |
77 WHEN CONSTRAINT_ERROR => | |
78 NULL; | |
79 WHEN OTHERS => | |
80 FAILED("UNEXPECTED EXCEPTION RAISED BY LARGE '+'"); | |
81 END; | |
82 | |
83 -- AS ABOVE BUT INTERCHANGING '+' AND '-' | |
84 BEGIN | |
85 F5 := IDENT(FLOAT5'BASE'LAST) - FLOAT5'BASE'LAST; | |
86 | |
87 IF NOT EQUAL(F5, F5) THEN | |
88 COMMENT("DON'T OPTIMIZE F5"); | |
89 END IF; | |
90 EXCEPTION | |
91 WHEN CONSTRAINT_ERROR => | |
92 FAILED("CONSTRAINT_ERROR " & | |
93 "RAISED BY INTERCHANGING LARGE '+'"); | |
94 WHEN OTHERS => | |
95 FAILED("UNEXPECTED EXCEPTION RAISED BY " & | |
96 "INTERCHANGING LARGE '+'"); | |
97 END; | |
98 | |
99 BEGIN | |
100 F5 := IDENT(FLOAT5'BASE'FIRST) + FLOAT5'BASE'FIRST; | |
101 | |
102 FAILED("NO EXCEPTION RAISED BY SMALL '+'"); | |
103 | |
104 IF NOT EQUAL(F5, F5) THEN | |
105 COMMENT("DON'T OPTIMIZE F5"); | |
106 END IF; | |
107 EXCEPTION | |
108 WHEN CONSTRAINT_ERROR => | |
109 NULL; | |
110 WHEN OTHERS => | |
111 FAILED("UNEXPECTED EXCEPTION RAISED BY SMALL '+'"); | |
112 END; | |
113 | |
114 -- AS ABOVE BUT INTERCHANGING '+' AND '-' | |
115 BEGIN | |
116 F5 := IDENT(FLOAT5'BASE'FIRST) - FLOAT5'BASE'FIRST; | |
117 | |
118 IF NOT EQUAL(F5, F5) THEN | |
119 COMMENT("DON'T OPTIMIZE F5"); | |
120 END IF; | |
121 EXCEPTION | |
122 WHEN CONSTRAINT_ERROR => | |
123 FAILED("CONSTRAINT_ERROR " & | |
124 "RAISED BY INTERCHANGING SMALL '+'"); | |
125 WHEN OTHERS => | |
126 FAILED("UNEXPECTED EXCEPTION RAISED BY " & | |
127 "INTERCHANGING SMALL '+'"); | |
128 END; | |
129 | |
130 BEGIN | |
131 F5 := IDENT(FLOAT5'BASE'LAST) - FLOAT5'BASE'FIRST; | |
132 | |
133 FAILED("NO EXCEPTION RAISED BY LARGE '-'"); | |
134 | |
135 IF NOT EQUAL(F5, F5) THEN | |
136 COMMENT("DON'T OPTIMIZE F5"); | |
137 END IF; | |
138 EXCEPTION | |
139 WHEN CONSTRAINT_ERROR => | |
140 NULL; | |
141 WHEN OTHERS => | |
142 FAILED("UNEXPECTED EXCEPTION RAISED BY LARGE '-'"); | |
143 END; | |
144 | |
145 -- AS ABOVE BUT INTERCHANGING '+' AND '-' | |
146 BEGIN | |
147 F5 := IDENT(FLOAT5'BASE'LAST) + FLOAT5'BASE'FIRST; | |
148 | |
149 IF NOT EQUAL(F5, F5) THEN | |
150 COMMENT("DON'T OPTIMIZE F5"); | |
151 END IF; | |
152 EXCEPTION | |
153 WHEN CONSTRAINT_ERROR => | |
154 FAILED("CONSTRAINT_ERROR " & | |
155 "RAISED BY INTERCHANGING LARGE '-'"); | |
156 WHEN OTHERS => | |
157 FAILED("UNEXPECTED EXCEPTION RAISED BY " & | |
158 "INTERCHANGING LARGE '-'"); | |
159 END; | |
160 | |
161 BEGIN | |
162 F5 := IDENT(FLOAT5'BASE'FIRST) - FLOAT5'BASE'LAST; | |
163 | |
164 FAILED("NO EXCEPTION RAISED BY SMALL '-'"); | |
165 | |
166 IF NOT EQUAL(F5, F5) THEN | |
167 COMMENT("DON'T OPTIMIZE F5"); | |
168 END IF; | |
169 EXCEPTION | |
170 WHEN CONSTRAINT_ERROR => | |
171 NULL; | |
172 WHEN OTHERS => | |
173 FAILED("UNEXPECTED EXCEPTION RAISED BY SMALL '-'"); | |
174 END; | |
175 | |
176 -- AS ABOVE BUT INTERCHANGING '+' AND '-' | |
177 BEGIN | |
178 F5 := IDENT(FLOAT5'BASE'FIRST) + FLOAT5'BASE'LAST; | |
179 | |
180 IF NOT EQUAL(F5, F5) THEN | |
181 COMMENT("DON'T OPTIMIZE F5"); | |
182 END IF; | |
183 EXCEPTION | |
184 WHEN CONSTRAINT_ERROR => | |
185 FAILED("CONSTRAINT_ERROR " & | |
186 "RAISED BY INTERCHANGING SMALL '-'"); | |
187 WHEN OTHERS => | |
188 FAILED("UNEXPECTED EXCEPTION RAISED BY " & | |
189 "INTERCHANGING SMALL '-'"); | |
190 END; | |
191 | |
192 END IF; | |
193 | |
194 RESULT; | |
195 | |
196 END C45322A; |