annotate gcc/testsuite/ada/acats/tests/cd/cd2b15c.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 -- CD2B15C.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 -- IF THE COLLECTION SIZE IS LARGE ENOUGH TO HOLD SOME
kono
parents:
diff changeset
27 -- VALUES OF THE DESIGNATED TYPE, CHECK THAT "STORAGE_ERROR"
kono
parents:
diff changeset
28 -- IS RAISED BY AN ALLOCATOR WHEN INSUFFICIENT STORAGE IS
kono
parents:
diff changeset
29 -- AVAILABLE.
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 -- HISTORY:
kono
parents:
diff changeset
32 -- DHH 09/23/87 CREATED ORIGINAL TEST.
kono
parents:
diff changeset
33 -- PMW 09/19/88 MODIFIED WITHDRAWN TEST.
kono
parents:
diff changeset
34 -- THS 03/21/90 CHANGED EXTENSION FROM '.DEP' TO '.ADA' AND
kono
parents:
diff changeset
35 -- COMPLETELY REVISED THE TEST TO PREVENT OPTIMIZATION.
kono
parents:
diff changeset
36 -- LDC 09/20/90 REMOVED UNUSED VARIABLE, CHANGED FAIL CALLS TO
kono
parents:
diff changeset
37 -- COMMENT FOR 'STORAGE_SIZE /= TO SPECIFIED SIZE,
kono
parents:
diff changeset
38 -- MOVED LOOP FOR CHECK VALUES TO EXCEPTION HANDLER.
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 WITH REPORT; USE REPORT;
kono
parents:
diff changeset
41 WITH SYSTEM;
kono
parents:
diff changeset
42 PROCEDURE CD2B15C IS
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 SPECIFIED_SIZE : CONSTANT := 1000;
kono
parents:
diff changeset
45
kono
parents:
diff changeset
46 TYPE CHECK_TYPE IS ACCESS INTEGER;
kono
parents:
diff changeset
47 FOR CHECK_TYPE'STORAGE_SIZE USE SPECIFIED_SIZE;
kono
parents:
diff changeset
48
kono
parents:
diff changeset
49 UNITS_PER_INTEGER : CONSTANT :=
kono
parents:
diff changeset
50 (INTEGER'SIZE + SYSTEM.STORAGE_UNIT - 1) / SYSTEM.STORAGE_UNIT;
kono
parents:
diff changeset
51
kono
parents:
diff changeset
52 TYPE ACC_ARRAY_TYPE IS ARRAY
kono
parents:
diff changeset
53 (INTEGER RANGE 1 .. (CHECK_TYPE'STORAGE_SIZE /
kono
parents:
diff changeset
54 UNITS_PER_INTEGER) + 1) OF CHECK_TYPE;
kono
parents:
diff changeset
55 ACC_ARRAY : ACC_ARRAY_TYPE;
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 PLACE_I_STOPPED : INTEGER := 0;
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 BEGIN
kono
parents:
diff changeset
60
kono
parents:
diff changeset
61 TEST ("CD2B15C", "IF THE COLLECTION SIZE IS LARGE " &
kono
parents:
diff changeset
62 "ENOUGH TO HOLD SOME VALUES OF " &
kono
parents:
diff changeset
63 "THE DESIGNATED TYPE, CHECK THAT " &
kono
parents:
diff changeset
64 "STORAGE_ERROR IS RAISED BY AN " &
kono
parents:
diff changeset
65 "ALLOCATOR WHEN INSUFFICIENT STORAGE " &
kono
parents:
diff changeset
66 "IS AVAILABLE");
kono
parents:
diff changeset
67
kono
parents:
diff changeset
68 IF CHECK_TYPE'STORAGE_SIZE < IDENT_INT (SPECIFIED_SIZE) THEN
kono
parents:
diff changeset
69 FAILED ("CHECK_TYPE'STORAGE_SIZE IS LESS THEN THE VALUE " &
kono
parents:
diff changeset
70 "SPECIFIED IN THE REPRESENTATION CLAUSE");
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72 ELSIF CHECK_TYPE'STORAGE_SIZE > 2 * IDENT_INT (SPECIFIED_SIZE) THEN
kono
parents:
diff changeset
73 COMMENT ("VALUE FOR CHECK_TYPE'STORAGE_SIZE IS MORE THEN " &
kono
parents:
diff changeset
74 "TWICE THE SPECIFIED VALUE IN THE REPRESENTATION " &
kono
parents:
diff changeset
75 "CLAUSE");
kono
parents:
diff changeset
76 END IF;
kono
parents:
diff changeset
77
kono
parents:
diff changeset
78 BEGIN
kono
parents:
diff changeset
79
kono
parents:
diff changeset
80 FOR I IN ACC_ARRAY'RANGE LOOP
kono
parents:
diff changeset
81 ACC_ARRAY (I) := NEW INTEGER'(IDENT_INT (I));
kono
parents:
diff changeset
82 PLACE_I_STOPPED := I;
kono
parents:
diff changeset
83 END LOOP;
kono
parents:
diff changeset
84
kono
parents:
diff changeset
85 FAILED ("NO EXCEPTION RAISED WHEN RESERVED SPACE " &
kono
parents:
diff changeset
86 "EXCEEDED");
kono
parents:
diff changeset
87
kono
parents:
diff changeset
88 EXCEPTION
kono
parents:
diff changeset
89 WHEN STORAGE_ERROR =>
kono
parents:
diff changeset
90 FOR I IN 1 .. PLACE_I_STOPPED LOOP
kono
parents:
diff changeset
91 IF ACC_ARRAY (I).ALL /= IDENT_INT (I) THEN
kono
parents:
diff changeset
92 FAILED ("INCORRECT VALUE FOR ACC_ARRAY (" &
kono
parents:
diff changeset
93 INTEGER'IMAGE (I) & ")");
kono
parents:
diff changeset
94 END IF;
kono
parents:
diff changeset
95 END LOOP;
kono
parents:
diff changeset
96 WHEN OTHERS =>
kono
parents:
diff changeset
97 FAILED ("WRONG EXCEPTION RAISED WHEN RESERVED SPACE " &
kono
parents:
diff changeset
98 "EXCEEDED");
kono
parents:
diff changeset
99 END;
kono
parents:
diff changeset
100
kono
parents:
diff changeset
101 RESULT;
kono
parents:
diff changeset
102
kono
parents:
diff changeset
103 END CD2B15C;