annotate gcc/testsuite/ada/acats/tests/cxa/cxa4033.a @ 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 -- CXA4033.A
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 --
kono
parents:
diff changeset
26 -- OBJECTIVE:
kono
parents:
diff changeset
27 -- Check that the functionality found in packages Ada.Strings.Wide_Maps,
kono
parents:
diff changeset
28 -- Ada.Strings.Wide_Unbounded, and Ada.Strings.Wide_Maps.Wide_Constants
kono
parents:
diff changeset
29 -- is available and produces correct results.
kono
parents:
diff changeset
30 --
kono
parents:
diff changeset
31 -- TEST DESCRIPTION:
kono
parents:
diff changeset
32 -- This test tests the subprograms found in the
kono
parents:
diff changeset
33 -- Ada.Strings.Wide_Unbounded package. It is based on the tests
kono
parents:
diff changeset
34 -- CXA4030-32, which are tests for the complementary "non-wide"
kono
parents:
diff changeset
35 -- packages.
kono
parents:
diff changeset
36 --
kono
parents:
diff changeset
37 -- The functions found in CXA4033_0 provide mapping capability, when
kono
parents:
diff changeset
38 -- used in conjunction with Wide_Character_Mapping_Function objects.
kono
parents:
diff changeset
39 --
kono
parents:
diff changeset
40 --
kono
parents:
diff changeset
41 -- CHANGE HISTORY:
kono
parents:
diff changeset
42 -- 23 Jun 95 SAIC Initial prerelease version.
kono
parents:
diff changeset
43 -- 24 Feb 97 PWB.CTA Removed attempt to create wide string of length
kono
parents:
diff changeset
44 -- Natural'Last
kono
parents:
diff changeset
45 --!
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 package CXA4033_0 is
kono
parents:
diff changeset
48 -- Functions used to supply mapping capability.
kono
parents:
diff changeset
49 function Map_To_Lower_Case (From : Wide_Character) return Wide_Character;
kono
parents:
diff changeset
50 function Map_To_Upper_Case (From : Wide_Character) return Wide_Character;
kono
parents:
diff changeset
51 end CXA4033_0;
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 with Ada.Characters.Handling;
kono
parents:
diff changeset
54 package body CXA4033_0 is
kono
parents:
diff changeset
55 -- Function Map_To_Lower_Case will return the lower case form of
kono
parents:
diff changeset
56 -- Wide_Characters in the range 'A'..'Z' only, and return the input
kono
parents:
diff changeset
57 -- wide_character otherwise.
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 function Map_To_Lower_Case (From : Wide_Character)
kono
parents:
diff changeset
60 return Wide_Character is
kono
parents:
diff changeset
61 begin
kono
parents:
diff changeset
62 return Ada.Characters.Handling.To_Wide_Character(
kono
parents:
diff changeset
63 Ada.Characters.Handling.To_Lower(
kono
parents:
diff changeset
64 Ada.Characters.Handling.To_Character(From)));
kono
parents:
diff changeset
65 end Map_To_Lower_Case;
kono
parents:
diff changeset
66
kono
parents:
diff changeset
67 -- Function Map_To_Upper_Case will return the upper case form of
kono
parents:
diff changeset
68 -- Wide_Characters in the range 'a'..'z', or whose position is in one
kono
parents:
diff changeset
69 -- of the ranges 223..246 or 248..255, provided the wide_character has
kono
parents:
diff changeset
70 -- an upper case form.
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72 function Map_To_Upper_Case (From : Wide_Character)
kono
parents:
diff changeset
73 return Wide_Character is
kono
parents:
diff changeset
74 begin
kono
parents:
diff changeset
75 return Ada.Characters.Handling.To_Wide_Character(
kono
parents:
diff changeset
76 Ada.Characters.Handling.To_Upper(
kono
parents:
diff changeset
77 Ada.Characters.Handling.To_Character(From)));
kono
parents:
diff changeset
78 end Map_To_Upper_Case;
kono
parents:
diff changeset
79
kono
parents:
diff changeset
80 end CXA4033_0;
kono
parents:
diff changeset
81
kono
parents:
diff changeset
82
kono
parents:
diff changeset
83 with CXA4033_0;
kono
parents:
diff changeset
84 with Report;
kono
parents:
diff changeset
85 with Ada.Characters.Handling;
kono
parents:
diff changeset
86 with Ada.Characters.Latin_1;
kono
parents:
diff changeset
87 with Ada.Strings;
kono
parents:
diff changeset
88 with Ada.Strings.Wide_Maps;
kono
parents:
diff changeset
89 with Ada.Strings.Wide_Maps.Wide_Constants;
kono
parents:
diff changeset
90 with Ada.Strings.Wide_Fixed;
kono
parents:
diff changeset
91 with Ada.Strings.Wide_Unbounded;
kono
parents:
diff changeset
92
kono
parents:
diff changeset
93 procedure CXA4033 is
kono
parents:
diff changeset
94 begin
kono
parents:
diff changeset
95 Report.Test ("CXA4033",
kono
parents:
diff changeset
96 "Check that subprograms defined in the package " &
kono
parents:
diff changeset
97 "Ada.Strings.Wide_Unbounded produce correct results");
kono
parents:
diff changeset
98
kono
parents:
diff changeset
99 Test_Block:
kono
parents:
diff changeset
100 declare
kono
parents:
diff changeset
101
kono
parents:
diff changeset
102 package ACL1 renames Ada.Characters.Latin_1;
kono
parents:
diff changeset
103 package Unb renames Ada.Strings.Wide_Unbounded;
kono
parents:
diff changeset
104
kono
parents:
diff changeset
105 subtype LC_Characters is Wide_Character range 'a'..'z';
kono
parents:
diff changeset
106
kono
parents:
diff changeset
107 use Ada.Characters, Ada.Strings, Unb;
kono
parents:
diff changeset
108 use type Wide_Maps.Wide_Character_Set;
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 TC_String : constant Wide_String := "A Standard String";
kono
parents:
diff changeset
111
kono
parents:
diff changeset
112 String_20 : Wide_String(1..20) := "ABCDEFGHIJKLMNOPQRST";
kono
parents:
diff changeset
113 String_40 : Wide_String(1..40) := "abcdefghijklmnopqrst" &
kono
parents:
diff changeset
114 String_20;
kono
parents:
diff changeset
115 String_80 : Wide_String(1..80) := String_40 & String_40;
kono
parents:
diff changeset
116 TC_String_5 : Wide_String(1..5) := "ABCDE";
kono
parents:
diff changeset
117 TC_Unb_String : Unbounded_Wide_String := Null_Unbounded_Wide_String;
kono
parents:
diff changeset
118
kono
parents:
diff changeset
119 -- The following strings are used in examination of the Translation
kono
parents:
diff changeset
120 -- subprograms.
kono
parents:
diff changeset
121 New_Character_String : Wide_String(1..10) :=
kono
parents:
diff changeset
122 Handling.To_Wide_String(
kono
parents:
diff changeset
123 ACL1.LC_A_Grave & ACL1.LC_A_Ring & ACL1.LC_AE_Diphthong &
kono
parents:
diff changeset
124 ACL1.LC_C_Cedilla & ACL1.LC_E_Acute & ACL1.LC_I_Circumflex &
kono
parents:
diff changeset
125 ACL1.LC_Icelandic_Eth & ACL1.LC_N_Tilde &
kono
parents:
diff changeset
126 ACL1.LC_O_Oblique_Stroke & ACL1.LC_Icelandic_Thorn);
kono
parents:
diff changeset
127
kono
parents:
diff changeset
128 TC_New_Character_String : Wide_String(1..10) :=
kono
parents:
diff changeset
129 Handling.To_Wide_String(
kono
parents:
diff changeset
130 ACL1.UC_A_Grave & ACL1.UC_A_Ring & ACL1.UC_AE_Diphthong &
kono
parents:
diff changeset
131 ACL1.UC_C_Cedilla & ACL1.UC_E_Acute & ACL1.UC_I_Circumflex &
kono
parents:
diff changeset
132 ACL1.UC_Icelandic_Eth & ACL1.UC_N_Tilde &
kono
parents:
diff changeset
133 ACL1.UC_O_Oblique_Stroke & ACL1.UC_Icelandic_Thorn);
kono
parents:
diff changeset
134
kono
parents:
diff changeset
135 New_UB_Character_String : Unbounded_Wide_String :=
kono
parents:
diff changeset
136 To_Unbounded_Wide_String(New_Character_String);
kono
parents:
diff changeset
137
kono
parents:
diff changeset
138 TC_New_UB_Character_String : Unbounded_Wide_String :=
kono
parents:
diff changeset
139 To_Unbounded_Wide_String(TC_New_Character_String);
kono
parents:
diff changeset
140
kono
parents:
diff changeset
141 -- Access objects that will be provided as parameters to the
kono
parents:
diff changeset
142 -- subprograms.
kono
parents:
diff changeset
143 Map_To_Lower_Case_Ptr : Wide_Maps.Wide_Character_Mapping_Function :=
kono
parents:
diff changeset
144 CXA4033_0.Map_To_Lower_Case'Access;
kono
parents:
diff changeset
145 Map_To_Upper_Case_Ptr : Wide_Maps.Wide_Character_Mapping_Function :=
kono
parents:
diff changeset
146 CXA4033_0.Map_To_Upper_Case'Access;
kono
parents:
diff changeset
147
kono
parents:
diff changeset
148 begin
kono
parents:
diff changeset
149
kono
parents:
diff changeset
150 -- Testing functionality found in Package Ada.Strings.Wide_Unbounded.
kono
parents:
diff changeset
151 --
kono
parents:
diff changeset
152 -- Function Index.
kono
parents:
diff changeset
153
kono
parents:
diff changeset
154 if Index(To_Unbounded_Wide_String("AAABBBaaabbb"),
kono
parents:
diff changeset
155 "aabb",
kono
parents:
diff changeset
156 Mapping => Map_To_Lower_Case_Ptr) /= 2 or
kono
parents:
diff changeset
157 Index(To_Unbounded_Wide_String("Case of a Mixed Case String"),
kono
parents:
diff changeset
158 "case",
kono
parents:
diff changeset
159 Ada.Strings.Backward,
kono
parents:
diff changeset
160 Map_To_Lower_Case_Ptr) /= 17
kono
parents:
diff changeset
161 then
kono
parents:
diff changeset
162 Report.Failed("Incorrect results from Function Index, " &
kono
parents:
diff changeset
163 "using a Wide Character Mapping Function parameter");
kono
parents:
diff changeset
164 end if;
kono
parents:
diff changeset
165
kono
parents:
diff changeset
166 -- Function Count.
kono
parents:
diff changeset
167 if Count(Source => To_Unbounded_Wide_String("ABABABA"),
kono
parents:
diff changeset
168 Pattern => "aba",
kono
parents:
diff changeset
169 Mapping => Map_To_Lower_Case_Ptr) /= 2 or
kono
parents:
diff changeset
170 Count(Null_Unbounded_Wide_String, "mat", Map_To_Upper_Case_Ptr) /= 0
kono
parents:
diff changeset
171 then
kono
parents:
diff changeset
172 Report.Failed("Incorrect results from Function Count, using " &
kono
parents:
diff changeset
173 "a Character Mapping Function parameter");
kono
parents:
diff changeset
174 end if;
kono
parents:
diff changeset
175
kono
parents:
diff changeset
176 -- Function Translate.
kono
parents:
diff changeset
177 if Translate(To_Unbounded_Wide_String("A Sample Mixed Case String"),
kono
parents:
diff changeset
178 Mapping => Map_To_Lower_Case_Ptr) /=
kono
parents:
diff changeset
179 To_Unbounded_Wide_String("a sample mixed case string") or
kono
parents:
diff changeset
180 Translate(New_UB_Character_String, Map_To_Upper_Case_Ptr) /=
kono
parents:
diff changeset
181 TC_New_UB_Character_String
kono
parents:
diff changeset
182 then
kono
parents:
diff changeset
183 Report.Failed("Incorrect results from Function Translate, " &
kono
parents:
diff changeset
184 "using a Character Mapping Function parameter");
kono
parents:
diff changeset
185 end if;
kono
parents:
diff changeset
186
kono
parents:
diff changeset
187 -- Procedure Translate.
kono
parents:
diff changeset
188 declare
kono
parents:
diff changeset
189 use Ada.Characters.Handling;
kono
parents:
diff changeset
190 Str : Unbounded_Wide_String :=
kono
parents:
diff changeset
191 To_Unbounded_Wide_String("AN ALL UPPER CASE STRING");
kono
parents:
diff changeset
192 begin
kono
parents:
diff changeset
193 Translate(Source => Str, Mapping => Map_To_Lower_Case_Ptr);
kono
parents:
diff changeset
194 if Str /= To_Unbounded_Wide_String("an all upper case string") then
kono
parents:
diff changeset
195 Report.Failed("Incorrect result from Procedure Translate 1");
kono
parents:
diff changeset
196 end if;
kono
parents:
diff changeset
197
kono
parents:
diff changeset
198 Translate(New_UB_Character_String, Map_To_Upper_Case_Ptr);
kono
parents:
diff changeset
199 if New_UB_Character_String /= TC_New_UB_Character_String then
kono
parents:
diff changeset
200 Report.Failed("Incorrect result from Procedure Translate 2");
kono
parents:
diff changeset
201 end if;
kono
parents:
diff changeset
202 end;
kono
parents:
diff changeset
203
kono
parents:
diff changeset
204 -- Function To_Unbounded_Wide_String (version with Length parameter)
kono
parents:
diff changeset
205 if Length(To_Unbounded_Wide_String(Length => 10)) /= 10 or
kono
parents:
diff changeset
206 Length(To_Unbounded_Wide_String(0)) /= 0 or
kono
parents:
diff changeset
207 Length( To_Unbounded_Wide_String(10) &
kono
parents:
diff changeset
208 To_Unbounded_Wide_String(1) &
kono
parents:
diff changeset
209 To_Unbounded_Wide_String(0) ) /= 10 + 1 + 0
kono
parents:
diff changeset
210 then
kono
parents:
diff changeset
211 Report.Failed
kono
parents:
diff changeset
212 ("Incorrect results from Function To_Unbounded_Wide_String " &
kono
parents:
diff changeset
213 "with Length parameter");
kono
parents:
diff changeset
214 end if;
kono
parents:
diff changeset
215
kono
parents:
diff changeset
216 -- Procedure Append (Wide_Unbounded - Wide_Unbounded)
kono
parents:
diff changeset
217 TC_Unb_String := Null_Unbounded_Wide_String;
kono
parents:
diff changeset
218 Append(TC_Unb_String, To_Unbounded_Wide_String("New Unbounded String"));
kono
parents:
diff changeset
219 if TC_Unb_String /= To_Unbounded_Wide_String("New Unbounded String")
kono
parents:
diff changeset
220 then
kono
parents:
diff changeset
221 Report.Failed("Incorrect results from Procedure Append with " &
kono
parents:
diff changeset
222 "unbounded wide string parameters");
kono
parents:
diff changeset
223 end if;
kono
parents:
diff changeset
224
kono
parents:
diff changeset
225
kono
parents:
diff changeset
226 -- Procedure Append (Wide_Unbounded - Wide_String)
kono
parents:
diff changeset
227 TC_Unb_String := To_Unbounded_Wide_String("An Unbounded String and ");
kono
parents:
diff changeset
228 Append(Source => TC_Unb_String, New_Item => TC_String);
kono
parents:
diff changeset
229 if TC_Unb_String /=
kono
parents:
diff changeset
230 To_Unbounded_Wide_String("An Unbounded String and A Standard String")
kono
parents:
diff changeset
231 then
kono
parents:
diff changeset
232 Report.Failed("Incorrect results from Procedure Append with " &
kono
parents:
diff changeset
233 "an unbounded wide string parameter and a wide " &
kono
parents:
diff changeset
234 "string parameter");
kono
parents:
diff changeset
235 end if;
kono
parents:
diff changeset
236
kono
parents:
diff changeset
237 -- Procedure Append (Wide_Unbounded - Wide_Character)
kono
parents:
diff changeset
238 TC_Unb_String := To_Unbounded_Wide_String("Lower Case = ");
kono
parents:
diff changeset
239 for i in LC_Characters'Range loop
kono
parents:
diff changeset
240 Append(Source => TC_Unb_String, New_Item => LC_Characters(i));
kono
parents:
diff changeset
241 end loop;
kono
parents:
diff changeset
242 if TC_Unb_String /=
kono
parents:
diff changeset
243 Unb.To_Unbounded_Wide_String
kono
parents:
diff changeset
244 ("Lower Case = abcdefghijklmnopqrstuvwxyz")
kono
parents:
diff changeset
245 then
kono
parents:
diff changeset
246 Report.Failed("Incorrect results from Procedure Append with " &
kono
parents:
diff changeset
247 "an unbounded wide string parameter and a wide " &
kono
parents:
diff changeset
248 "character parameter");
kono
parents:
diff changeset
249 end if;
kono
parents:
diff changeset
250
kono
parents:
diff changeset
251 -- Function "="
kono
parents:
diff changeset
252 TC_Unb_String := To_Unbounded_Wide_String(TC_String);
kono
parents:
diff changeset
253 if not (TC_Unb_String = TC_String) or
kono
parents:
diff changeset
254 not "="("A Standard String", TC_Unb_String) or
kono
parents:
diff changeset
255 not ((Null_Unbounded_Wide_String = "") and
kono
parents:
diff changeset
256 ("Test String" = To_Unbounded_Wide_String("Test String")))
kono
parents:
diff changeset
257 then
kono
parents:
diff changeset
258 Report.Failed("Incorrect results from Function ""="" with " &
kono
parents:
diff changeset
259 "wide_string - unbounded wide string parameters");
kono
parents:
diff changeset
260 end if;
kono
parents:
diff changeset
261
kono
parents:
diff changeset
262 -- Function "<"
kono
parents:
diff changeset
263 if not ("Extra Space" < To_Unbounded_Wide_String("Extra Space ") and
kono
parents:
diff changeset
264 To_Unbounded_Wide_String("tess") < "test" and
kono
parents:
diff changeset
265 To_Unbounded_Wide_String("best") < "test")
kono
parents:
diff changeset
266 then
kono
parents:
diff changeset
267 Report.Failed("Incorrect results from Function ""<"" with " &
kono
parents:
diff changeset
268 "wide string - unbounded wide string parameters");
kono
parents:
diff changeset
269 end if;
kono
parents:
diff changeset
270
kono
parents:
diff changeset
271 -- Function "<="
kono
parents:
diff changeset
272 TC_Unb_String := To_Unbounded_Wide_String("Sample string");
kono
parents:
diff changeset
273 if TC_Unb_String <= "Sample strin" or
kono
parents:
diff changeset
274 not("Sample string" <= TC_Unb_String)
kono
parents:
diff changeset
275 then
kono
parents:
diff changeset
276 Report.Failed("Incorrect results from Function ""<="" with " &
kono
parents:
diff changeset
277 "wide string - unbounded wide string parameters");
kono
parents:
diff changeset
278 end if;
kono
parents:
diff changeset
279
kono
parents:
diff changeset
280 -- Function ">"
kono
parents:
diff changeset
281 TC_Unb_String := To_Unbounded_Wide_String("A MUCH LONGER STRING");
kono
parents:
diff changeset
282 if not ("A much longer string" > TC_Unb_String and
kono
parents:
diff changeset
283 To_Unbounded_Wide_String(TC_String) > "A Standard Strin" and
kono
parents:
diff changeset
284 "abcdefgh" > To_Unbounded_Wide_String("ABCDEFGH"))
kono
parents:
diff changeset
285 then
kono
parents:
diff changeset
286 Report.Failed("Incorrect results from Function "">"" with " &
kono
parents:
diff changeset
287 "wide string - unbounded wide string parameters");
kono
parents:
diff changeset
288 end if;
kono
parents:
diff changeset
289
kono
parents:
diff changeset
290 -- Function ">="
kono
parents:
diff changeset
291 TC_Unb_String := To_Unbounded_Wide_String(TC_String);
kono
parents:
diff changeset
292 if not (TC_Unb_String >= TC_String and
kono
parents:
diff changeset
293 "test" >= To_Unbounded_Wide_String("tess") and
kono
parents:
diff changeset
294 To_Unbounded_Wide_String("Programming") >= "PROGRAMMING")
kono
parents:
diff changeset
295 then
kono
parents:
diff changeset
296 Report.Failed("Incorrect results from Function "">="" with " &
kono
parents:
diff changeset
297 "wide string - unbounded wide string parameters");
kono
parents:
diff changeset
298 end if;
kono
parents:
diff changeset
299
kono
parents:
diff changeset
300 -- Procedure Replace_Slice
kono
parents:
diff changeset
301 TC_Unb_String := To_Unbounded_Wide_String("Test String");
kono
parents:
diff changeset
302 Replace_Slice(TC_Unb_String, 5, 5, TC_String_5);
kono
parents:
diff changeset
303 if TC_Unb_String /= To_Unbounded_Wide_String("TestABCDEString") then
kono
parents:
diff changeset
304 Report.Failed("Incorrect results from Replace_Slice - 1");
kono
parents:
diff changeset
305 end if;
kono
parents:
diff changeset
306
kono
parents:
diff changeset
307 Replace_Slice(TC_Unb_String, 1, 4, TC_String_5);
kono
parents:
diff changeset
308 if TC_Unb_String /= To_Unbounded_Wide_String("ABCDEABCDEString") then
kono
parents:
diff changeset
309 Report.Failed("Incorrect results from Replace_Slice - 2");
kono
parents:
diff changeset
310 end if;
kono
parents:
diff changeset
311
kono
parents:
diff changeset
312 -- Procedure Insert
kono
parents:
diff changeset
313 TC_Unb_String := To_Unbounded_Wide_String("Test String");
kono
parents:
diff changeset
314 Insert(TC_Unb_String, 1, "**");
kono
parents:
diff changeset
315 if TC_Unb_String /= To_Unbounded_Wide_String("**Test String") then
kono
parents:
diff changeset
316 Report.Failed("Incorrect results from Procedure Insert - 1");
kono
parents:
diff changeset
317 end if;
kono
parents:
diff changeset
318
kono
parents:
diff changeset
319 Insert(TC_Unb_String, Length(TC_Unb_String)+1, "**");
kono
parents:
diff changeset
320 if TC_Unb_String /= To_Unbounded_Wide_String("**Test String**") then
kono
parents:
diff changeset
321 Report.Failed("Incorrect results from Procedure Insert - 2");
kono
parents:
diff changeset
322 end if;
kono
parents:
diff changeset
323
kono
parents:
diff changeset
324 -- Procedure Overwrite
kono
parents:
diff changeset
325 TC_Unb_String := To_Unbounded_Wide_String("Test String");
kono
parents:
diff changeset
326 Overwrite(TC_Unb_String, 1, New_Item => "XXXX");
kono
parents:
diff changeset
327 if TC_Unb_String /= To_Unbounded_Wide_String("XXXX String") then
kono
parents:
diff changeset
328 Report.Failed("Incorrect results from Procedure Overwrite - 1");
kono
parents:
diff changeset
329 end if;
kono
parents:
diff changeset
330
kono
parents:
diff changeset
331 Overwrite(TC_Unb_String, Length(TC_Unb_String)+1, "**");
kono
parents:
diff changeset
332 if TC_Unb_String /= To_Unbounded_Wide_String("XXXX String**") then
kono
parents:
diff changeset
333 Report.Failed("Incorrect results from Procedure Overwrite - 2");
kono
parents:
diff changeset
334 end if;
kono
parents:
diff changeset
335
kono
parents:
diff changeset
336 -- Procedure Delete
kono
parents:
diff changeset
337 TC_Unb_String := To_Unbounded_Wide_String("Test String");
kono
parents:
diff changeset
338 Delete(TC_Unb_String, 1, 0);
kono
parents:
diff changeset
339 if TC_Unb_String /= To_Unbounded_Wide_String("Test String") then
kono
parents:
diff changeset
340 Report.Failed("Incorrect results from Procedure Delete - 1");
kono
parents:
diff changeset
341 end if;
kono
parents:
diff changeset
342
kono
parents:
diff changeset
343 Delete(TC_Unb_String, 1, 5);
kono
parents:
diff changeset
344 if TC_Unb_String /= To_Unbounded_Wide_String("String") then
kono
parents:
diff changeset
345 Report.Failed("Incorrect results from Procedure Delete - 2");
kono
parents:
diff changeset
346 end if;
kono
parents:
diff changeset
347
kono
parents:
diff changeset
348 -- Procedure Trim
kono
parents:
diff changeset
349 TC_Unb_String := To_Unbounded_Wide_String(" Leading Spaces ");
kono
parents:
diff changeset
350 Trim(TC_Unb_String, Ada.Strings.Left);
kono
parents:
diff changeset
351 if TC_Unb_String /= To_Unbounded_Wide_String("Leading Spaces ") then
kono
parents:
diff changeset
352 Report.Failed("Incorrect results from Procedure Trim - 1");
kono
parents:
diff changeset
353 end if;
kono
parents:
diff changeset
354
kono
parents:
diff changeset
355 TC_Unb_String :=
kono
parents:
diff changeset
356 To_Unbounded_Wide_String(" Spaces on both ends ");
kono
parents:
diff changeset
357 Trim(TC_Unb_String, Ada.Strings.Both);
kono
parents:
diff changeset
358 if TC_Unb_String /=
kono
parents:
diff changeset
359 To_Unbounded_Wide_String("Spaces on both ends")
kono
parents:
diff changeset
360 then
kono
parents:
diff changeset
361 Report.Failed("Incorrect results from Procedure Trim - 2");
kono
parents:
diff changeset
362 end if;
kono
parents:
diff changeset
363
kono
parents:
diff changeset
364 -- Procedure Trim (with Wide_Character_Set parameters)
kono
parents:
diff changeset
365 TC_Unb_String := To_Unbounded_Wide_String("012abcdefghGFEDCBA789ab");
kono
parents:
diff changeset
366 Trim(TC_Unb_String,
kono
parents:
diff changeset
367 Ada.Strings.Wide_Maps.Wide_Constants.Hexadecimal_Digit_Set,
kono
parents:
diff changeset
368 Ada.Strings.Wide_Maps.Wide_Constants.Hexadecimal_Digit_Set);
kono
parents:
diff changeset
369 if TC_Unb_String /= To_Unbounded_Wide_String("ghG") then
kono
parents:
diff changeset
370 Report.Failed("Incorrect results from Procedure Trim with Sets");
kono
parents:
diff changeset
371 end if;
kono
parents:
diff changeset
372
kono
parents:
diff changeset
373 -- Procedure Head
kono
parents:
diff changeset
374 TC_Unb_String := To_Unbounded_Wide_String("Test String");
kono
parents:
diff changeset
375 Head(Source => TC_Unb_String, Count => 0, Pad => '*');
kono
parents:
diff changeset
376 if TC_Unb_String /= Null_Unbounded_Wide_String then
kono
parents:
diff changeset
377 Report.Failed("Incorrect results from Procedure Head - 1");
kono
parents:
diff changeset
378 end if;
kono
parents:
diff changeset
379
kono
parents:
diff changeset
380 TC_Unb_String := To_Unbounded_Wide_String("Test String");
kono
parents:
diff changeset
381 Head(Source => TC_Unb_String, Count => 4, Pad => '*');
kono
parents:
diff changeset
382 if TC_Unb_String /= To_Unbounded_Wide_String("Test") then
kono
parents:
diff changeset
383 Report.Failed("Incorrect results from Procedure Head - 2");
kono
parents:
diff changeset
384 end if;
kono
parents:
diff changeset
385
kono
parents:
diff changeset
386 -- Procedure Tail
kono
parents:
diff changeset
387 TC_Unb_String := To_Unbounded_Wide_String("Test String");
kono
parents:
diff changeset
388 Tail(Source => TC_Unb_String, Count => 0, Pad => '*');
kono
parents:
diff changeset
389 if TC_Unb_String /= Null_Unbounded_Wide_String then
kono
parents:
diff changeset
390 Report.Failed("Incorrect results from Procedure Tail - 1");
kono
parents:
diff changeset
391 end if;
kono
parents:
diff changeset
392
kono
parents:
diff changeset
393 TC_Unb_String := To_Unbounded_Wide_String("Test String");
kono
parents:
diff changeset
394 Tail(TC_Unb_String, Length(TC_Unb_String) + 5, 'x');
kono
parents:
diff changeset
395 if TC_Unb_String /= To_Unbounded_Wide_String("xxxxxTest String") then
kono
parents:
diff changeset
396 Report.Failed("Incorrect results from Procedure Tail - 2");
kono
parents:
diff changeset
397 end if;
kono
parents:
diff changeset
398
kono
parents:
diff changeset
399 exception
kono
parents:
diff changeset
400 when others => Report.Failed ("Exception raised in Test_Block");
kono
parents:
diff changeset
401 end Test_Block;
kono
parents:
diff changeset
402
kono
parents:
diff changeset
403 Report.Result;
kono
parents:
diff changeset
404
kono
parents:
diff changeset
405 end CXA4033;