1 |
149 |
jeremybenn |
-- CXA4027.A
|
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 |
|
|
--
|
26 |
|
|
-- OBJECTIVE:
|
27 |
|
|
-- Check that versions of Ada.Strings.Bounded subprograms Translate,
|
28 |
|
|
-- (procedure and function), Index, and Count, which use the
|
29 |
|
|
-- Maps.Character_Mapping_Function input parameter, produce correct
|
30 |
|
|
-- results.
|
31 |
|
|
--
|
32 |
|
|
-- TEST DESCRIPTION:
|
33 |
|
|
-- This test examines the operation of several subprograms from within
|
34 |
|
|
-- the Ada.Strings.Bounded package that use the
|
35 |
|
|
-- Character_Mapping_Function mapping parameter to provide a mapping
|
36 |
|
|
-- capability.
|
37 |
|
|
--
|
38 |
|
|
-- Two functions are defined to provide the mapping. Access values
|
39 |
|
|
-- are defined to refer to these functions. One of the functions will
|
40 |
|
|
-- map upper case characters in the range 'A'..'Z' to their lower case
|
41 |
|
|
-- counterparts, while the other function will map lower case characters
|
42 |
|
|
-- ('a'..'z', or a character whose position is in one of the ranges
|
43 |
|
|
-- 223..246 or 248..255, provided the character has an upper case form)
|
44 |
|
|
-- to their upper case form.
|
45 |
|
|
--
|
46 |
|
|
-- Function Index uses the mapping function access value to map the input
|
47 |
|
|
-- string prior to searching for the appropriate index value to return.
|
48 |
|
|
-- Function Count uses the mapping function access value to map the input
|
49 |
|
|
-- string prior to counting the occurrences of the pattern string.
|
50 |
|
|
-- Both the Procedure and Function version of Translate use the mapping
|
51 |
|
|
-- function access value to perform the translation.
|
52 |
|
|
--
|
53 |
|
|
--
|
54 |
|
|
-- CHANGE HISTORY:
|
55 |
|
|
-- 16 FEB 95 SAIC Initial prerelease version
|
56 |
|
|
-- 17 Jul 95 SAIC Incorporated reviewer comments. Replaced two
|
57 |
|
|
-- internally declared functions with two library
|
58 |
|
|
-- level functions to eliminate accessibility
|
59 |
|
|
-- problems.
|
60 |
|
|
--
|
61 |
|
|
--!
|
62 |
|
|
|
63 |
|
|
|
64 |
|
|
-- Function CXA4027_0 will return the lower case form of
|
65 |
|
|
-- the character input if it is in upper case, and return the input
|
66 |
|
|
-- character otherwise.
|
67 |
|
|
|
68 |
|
|
with Ada.Characters.Handling;
|
69 |
|
|
function CXA4027_0 (From : Character) return Character;
|
70 |
|
|
|
71 |
|
|
function CXA4027_0 (From : Character) return Character is
|
72 |
|
|
begin
|
73 |
|
|
return Ada.Characters.Handling.To_Lower(From);
|
74 |
|
|
end CXA4027_0;
|
75 |
|
|
|
76 |
|
|
|
77 |
|
|
|
78 |
|
|
-- Function CXA4027_1 will return the upper case form of
|
79 |
|
|
-- Characters in the range 'a'..'z', or whose position is in one
|
80 |
|
|
-- of the ranges 223..246 or 248..255, provided the character has
|
81 |
|
|
-- an upper case form.
|
82 |
|
|
|
83 |
|
|
with Ada.Characters.Handling;
|
84 |
|
|
function CXA4027_1 (From : Character) return Character;
|
85 |
|
|
|
86 |
|
|
function CXA4027_1 (From : Character) return Character is
|
87 |
|
|
begin
|
88 |
|
|
return Ada.Characters.Handling.To_Upper(From);
|
89 |
|
|
end CXA4027_1;
|
90 |
|
|
|
91 |
|
|
|
92 |
|
|
with CXA4027_0, CXA4027_1;
|
93 |
|
|
with Ada.Strings.Bounded;
|
94 |
|
|
with Ada.Strings.Maps;
|
95 |
|
|
with Ada.Characters.Handling;
|
96 |
|
|
with Report;
|
97 |
|
|
|
98 |
|
|
procedure CXA4027 is
|
99 |
|
|
begin
|
100 |
|
|
|
101 |
|
|
Report.Test ("CXA4027", "Check that Ada.Strings.Bounded subprograms " &
|
102 |
|
|
"Translate, Index, and Count, which use the " &
|
103 |
|
|
"Character_Mapping_Function input parameter, " &
|
104 |
|
|
"produce correct results");
|
105 |
|
|
|
106 |
|
|
Test_Block:
|
107 |
|
|
declare
|
108 |
|
|
|
109 |
|
|
use Ada.Strings;
|
110 |
|
|
|
111 |
|
|
-- Functions used to supply mapping capability.
|
112 |
|
|
|
113 |
|
|
function Map_To_Lower_Case (From : Character) return Character
|
114 |
|
|
renames CXA4027_0;
|
115 |
|
|
|
116 |
|
|
function Map_To_Upper_Case (From : Character) return Character
|
117 |
|
|
renames CXA4027_1;
|
118 |
|
|
|
119 |
|
|
Map_To_Lower_Case_Ptr : Maps.Character_Mapping_Function :=
|
120 |
|
|
Map_To_Lower_Case'Access;
|
121 |
|
|
|
122 |
|
|
Map_To_Upper_Case_Ptr : Maps.Character_Mapping_Function :=
|
123 |
|
|
Map_To_Upper_Case'Access;
|
124 |
|
|
|
125 |
|
|
|
126 |
|
|
-- Instantiations of Bounded String generic package.
|
127 |
|
|
|
128 |
|
|
package BS1 is new Ada.Strings.Bounded.Generic_Bounded_Length(1);
|
129 |
|
|
package BS20 is new Ada.Strings.Bounded.Generic_Bounded_Length(20);
|
130 |
|
|
package BS40 is new Ada.Strings.Bounded.Generic_Bounded_Length(40);
|
131 |
|
|
package BS80 is new Ada.Strings.Bounded.Generic_Bounded_Length(80);
|
132 |
|
|
|
133 |
|
|
use type BS1.Bounded_String, BS20.Bounded_String,
|
134 |
|
|
BS40.Bounded_String, BS80.Bounded_String;
|
135 |
|
|
|
136 |
|
|
String_1 : String(1..1) := "A";
|
137 |
|
|
String_20 : String(1..20) := "ABCDEFGHIJKLMNOPQRST";
|
138 |
|
|
String_40 : String(1..40) := "abcdefghijklmnopqrst" & String_20;
|
139 |
|
|
String_80 : String(1..80) := String_40 & String_40;
|
140 |
|
|
|
141 |
|
|
BString_1 : BS1.Bounded_String := BS1.Null_Bounded_String;
|
142 |
|
|
BString_20 : BS20.Bounded_String := BS20.Null_Bounded_String;
|
143 |
|
|
BString_40 : BS40.Bounded_String := BS40.Null_Bounded_String;
|
144 |
|
|
BString_80 : BS80.Bounded_String := BS80.Null_Bounded_String;
|
145 |
|
|
|
146 |
|
|
|
147 |
|
|
begin
|
148 |
|
|
|
149 |
|
|
-- Function Index.
|
150 |
|
|
|
151 |
|
|
if BS40.Index(BS40.To_Bounded_String("Package Strings.Bounded"),
|
152 |
|
|
Pattern => "s.b",
|
153 |
|
|
Going => Ada.Strings.Forward,
|
154 |
|
|
Mapping => Map_To_Lower_Case_Ptr) /= 15 or
|
155 |
|
|
BS80.Index(BS80.To_Bounded_String("STRING TRANSLATIONS SUBPROGRAMS"),
|
156 |
|
|
"tr",
|
157 |
|
|
Mapping => Map_To_Lower_Case_Ptr) /= 2 or
|
158 |
|
|
BS20.Index(BS20.To_Bounded_String("maximum number"),
|
159 |
|
|
"um",
|
160 |
|
|
Ada.Strings.Backward,
|
161 |
|
|
Map_To_Lower_Case_Ptr) /= 10 or
|
162 |
|
|
BS80.Index(BS80.To_Bounded_String("CoMpLeTeLy MiXeD CaSe StRiNg"),
|
163 |
|
|
"MIXED CASE STRING",
|
164 |
|
|
Ada.Strings.Forward,
|
165 |
|
|
Map_To_Upper_Case_Ptr) /= 12 or
|
166 |
|
|
BS40.Index(BS40.To_Bounded_String("STRING WITH NO MATCHING PATTERN"),
|
167 |
|
|
"WITH",
|
168 |
|
|
Ada.Strings.Backward,
|
169 |
|
|
Map_To_Lower_Case_Ptr) /= 0 or
|
170 |
|
|
BS80.Index(BS80.To_Bounded_String("THIS STRING IS IN UPPER CASE"),
|
171 |
|
|
"I",
|
172 |
|
|
Ada.Strings.Backward,
|
173 |
|
|
Map_To_Upper_Case_Ptr) /= 16 or
|
174 |
|
|
BS1.Index(BS1.Null_Bounded_String,
|
175 |
|
|
"i",
|
176 |
|
|
Mapping => Map_To_Lower_Case_Ptr) /= 0 or
|
177 |
|
|
BS40.Index(BS40.To_Bounded_String("AAABBBaaabbb"),
|
178 |
|
|
"aabb",
|
179 |
|
|
Mapping => Map_To_Lower_Case_Ptr) /= 2 or
|
180 |
|
|
BS80.Index(BS80.To_Bounded_String("WOULD MATCH BUT FOR THE CASE"),
|
181 |
|
|
"WOULD MATCH BUT FOR THE CASE",
|
182 |
|
|
Ada.Strings.Backward,
|
183 |
|
|
Map_To_Lower_Case_Ptr) /= 0
|
184 |
|
|
then
|
185 |
|
|
Report.Failed("Incorrect results from Function Index, using a " &
|
186 |
|
|
"Character Mapping Function parameter");
|
187 |
|
|
end if;
|
188 |
|
|
|
189 |
|
|
|
190 |
|
|
-- Function Index, Pattern_Error if Pattern = Null_String
|
191 |
|
|
|
192 |
|
|
declare
|
193 |
|
|
use BS20;
|
194 |
|
|
TC_Natural : Natural := 1000;
|
195 |
|
|
begin
|
196 |
|
|
TC_Natural := Index(To_Bounded_String("A Valid String"),
|
197 |
|
|
"",
|
198 |
|
|
Ada.Strings.Forward,
|
199 |
|
|
Map_To_Lower_Case_Ptr);
|
200 |
|
|
Report.Failed("Pattern_Error not raised by Function Index when " &
|
201 |
|
|
"given a null pattern string");
|
202 |
|
|
exception
|
203 |
|
|
when Pattern_Error => null; -- OK, expected exception.
|
204 |
|
|
when others =>
|
205 |
|
|
Report.Failed("Incorrect exception raised by Function Index " &
|
206 |
|
|
"using a Character_Mapping_Function parameter " &
|
207 |
|
|
"when given a null pattern string");
|
208 |
|
|
end;
|
209 |
|
|
|
210 |
|
|
|
211 |
|
|
-- Function Count.
|
212 |
|
|
|
213 |
|
|
if BS20.Count(BS20.To_Bounded_String("ABABABA"),
|
214 |
|
|
Pattern => "aba",
|
215 |
|
|
Mapping => Map_To_Lower_Case_Ptr) /= 2 or
|
216 |
|
|
BS20.Count(BS20.To_Bounded_String("ABABABA"),
|
217 |
|
|
"ABA",
|
218 |
|
|
Map_To_Lower_Case_Ptr) /= 0 or
|
219 |
|
|
BS40.Count(BS40.To_Bounded_String("This IS a MISmatched issue"),
|
220 |
|
|
"is",
|
221 |
|
|
Map_To_Lower_Case_Ptr) /= 4 or
|
222 |
|
|
BS80.Count(BS80.To_Bounded_String("ABABABA"),
|
223 |
|
|
"ABA",
|
224 |
|
|
Map_To_Upper_Case_Ptr) /= 2 or
|
225 |
|
|
BS40.Count(BS40.To_Bounded_String("This IS a MISmatched issue"),
|
226 |
|
|
"is",
|
227 |
|
|
Map_To_Upper_Case_Ptr) /= 0 or
|
228 |
|
|
BS80.Count(BS80.To_Bounded_String
|
229 |
|
|
("Peter Piper and his Pickled Peppers"),
|
230 |
|
|
"p",
|
231 |
|
|
Map_To_Lower_Case_Ptr) /= 7 or
|
232 |
|
|
BS20.Count(BS20.To_Bounded_String("She sells sea shells"),
|
233 |
|
|
"s",
|
234 |
|
|
Map_To_Upper_Case_Ptr) /= 0 or
|
235 |
|
|
BS80.Count(BS80.To_Bounded_String("No matches what-so-ever"),
|
236 |
|
|
"matches",
|
237 |
|
|
Map_To_Upper_Case_Ptr) /= 0
|
238 |
|
|
then
|
239 |
|
|
Report.Failed("Incorrect results from Function Count, using " &
|
240 |
|
|
"a Character_Mapping_Function parameter");
|
241 |
|
|
end if;
|
242 |
|
|
|
243 |
|
|
|
244 |
|
|
-- Function Count, Pattern_Error if Pattern = Null_String
|
245 |
|
|
|
246 |
|
|
declare
|
247 |
|
|
use BS80;
|
248 |
|
|
TC_Natural : Natural := 1000;
|
249 |
|
|
begin
|
250 |
|
|
TC_Natural := Count(To_Bounded_String("A Valid String"),
|
251 |
|
|
"",
|
252 |
|
|
Map_To_Lower_Case_Ptr);
|
253 |
|
|
Report.Failed("Pattern_Error not raised by Function Count using " &
|
254 |
|
|
"a Character_Mapping_Function parameter when " &
|
255 |
|
|
"given a null pattern string");
|
256 |
|
|
exception
|
257 |
|
|
when Pattern_Error => null; -- OK, expected exception.
|
258 |
|
|
when others =>
|
259 |
|
|
Report.Failed("Incorrect exception raised by Function Count " &
|
260 |
|
|
"using a Character_Mapping_Function parameter " &
|
261 |
|
|
"when given a null pattern string");
|
262 |
|
|
end;
|
263 |
|
|
|
264 |
|
|
|
265 |
|
|
-- Function Translate.
|
266 |
|
|
|
267 |
|
|
if BS40.Translate(BS40.To_Bounded_String("A Mixed Case String"),
|
268 |
|
|
Mapping => Map_To_Lower_Case_Ptr) /=
|
269 |
|
|
BS40.To_Bounded_String("a mixed case string") or
|
270 |
|
|
|
271 |
|
|
BS20."/="(BS20.Translate(BS20.To_Bounded_String("ALL LOWER CASE"),
|
272 |
|
|
Map_To_Lower_Case_Ptr),
|
273 |
|
|
"all lower case") or
|
274 |
|
|
|
275 |
|
|
BS20."/="("end with lower case",
|
276 |
|
|
BS20.Translate(
|
277 |
|
|
BS20.To_Bounded_String("end with lower case"),
|
278 |
|
|
Map_To_Lower_Case_Ptr)) or
|
279 |
|
|
|
280 |
|
|
BS1.Translate(BS1.Null_Bounded_String,
|
281 |
|
|
Map_To_Lower_Case_Ptr) /=
|
282 |
|
|
BS1.Null_Bounded_String or
|
283 |
|
|
|
284 |
|
|
BS80."/="(BS80.Translate(BS80.To_Bounded_String
|
285 |
|
|
("start with lower case, end with upper case"),
|
286 |
|
|
Map_To_Upper_Case_Ptr),
|
287 |
|
|
"START WITH LOWER CASE, END WITH UPPER CASE") or
|
288 |
|
|
|
289 |
|
|
BS40.Translate(BS40.To_Bounded_String("ALL UPPER CASE STRING"),
|
290 |
|
|
Map_To_Upper_Case_Ptr) /=
|
291 |
|
|
BS40.To_Bounded_String("ALL UPPER CASE STRING") or
|
292 |
|
|
|
293 |
|
|
BS80."/="(BS80.Translate(BS80.To_Bounded_String
|
294 |
|
|
("LoTs Of MiXeD CaSe ChArAcTeRs In ThE StRiNg"),
|
295 |
|
|
Map_To_Upper_Case_Ptr),
|
296 |
|
|
"LOTS OF MIXED CASE CHARACTERS IN THE STRING")
|
297 |
|
|
|
298 |
|
|
then
|
299 |
|
|
Report.Failed("Incorrect results from Function Translate, using " &
|
300 |
|
|
"a Character_Mapping_Function parameter");
|
301 |
|
|
end if;
|
302 |
|
|
|
303 |
|
|
|
304 |
|
|
-- Procedure Translate.
|
305 |
|
|
|
306 |
|
|
BString_1 := BS1.To_Bounded_String("A");
|
307 |
|
|
|
308 |
|
|
BS1.Translate(Source => BString_1, Mapping => Map_To_Lower_Case_Ptr);
|
309 |
|
|
|
310 |
|
|
if not BS1."="(BString_1, "a") then -- "=" for Bounded_String, String
|
311 |
|
|
Report.Failed("Incorrect result from Procedure Translate - 1");
|
312 |
|
|
end if;
|
313 |
|
|
|
314 |
|
|
BString_20 := BS20.To_Bounded_String(String_20);
|
315 |
|
|
BS20.Translate(BString_20, Mapping => Map_To_Lower_Case_Ptr);
|
316 |
|
|
|
317 |
|
|
if BString_20 /= BS20.To_Bounded_String("abcdefghijklmnopqrst") then
|
318 |
|
|
Report.Failed("Incorrect result from Procedure Translate - 2");
|
319 |
|
|
end if;
|
320 |
|
|
|
321 |
|
|
BString_40 := BS40.To_Bounded_String("String needing highlighting");
|
322 |
|
|
BS40.Translate(BString_40, Map_To_Upper_Case_Ptr);
|
323 |
|
|
|
324 |
|
|
if not (BString_40 = "STRING NEEDING HIGHLIGHTING") then
|
325 |
|
|
Report.Failed("Incorrect result from Procedure Translate - 3");
|
326 |
|
|
end if;
|
327 |
|
|
|
328 |
|
|
BString_80 := BS80.Null_Bounded_String;
|
329 |
|
|
BS80.Translate(BString_80, Map_To_Upper_Case_Ptr);
|
330 |
|
|
|
331 |
|
|
if not (BString_80 = BS80.Null_Bounded_String) then
|
332 |
|
|
Report.Failed("Incorrect result from Procedure Translate - 4");
|
333 |
|
|
end if;
|
334 |
|
|
|
335 |
|
|
|
336 |
|
|
exception
|
337 |
|
|
when others => Report.Failed ("Exception raised in Test_Block");
|
338 |
|
|
end Test_Block;
|
339 |
|
|
|
340 |
|
|
Report.Result;
|
341 |
|
|
|
342 |
|
|
end CXA4027;
|