1 ------------------------------------------------------------------------------
3 -- GNAT RUN-TIME COMPONENTS --
5 -- A D A . W I D E _ C H A R A C T E R S . H A N D L I N G --
9 -- Copyright (C) 2010-2017, Free Software Foundation, Inc. --
11 -- GNAT is free software; you can redistribute it and/or modify it under --
12 -- terms of the GNU General Public License as published by the Free Soft- --
13 -- ware Foundation; either version 3, or (at your option) any later ver- --
14 -- sion. GNAT is distributed in the hope that it will be useful, but WITH- --
15 -- OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY --
16 -- or FITNESS FOR A PARTICULAR PURPOSE. --
18 -- As a special exception under Section 7 of GPL version 3, you are granted --
19 -- additional permissions described in the GCC Runtime Library Exception, --
20 -- version 3.1, as published by the Free Software Foundation. --
22 -- You should have received a copy of the GNU General Public License and --
23 -- a copy of the GCC Runtime Library Exception along with this program; --
24 -- see the files COPYING3 and COPYING.RUNTIME respectively. If not, see --
25 -- <http://www.gnu.org/licenses/>. --
27 -- GNAT was originally developed by the GNAT team at New York University. --
28 -- Extensive contributions were provided by Ada Core Technologies Inc. --
30 ------------------------------------------------------------------------------
32 with Ada
.Wide_Characters
.Unicode
; use Ada
.Wide_Characters
.Unicode
;
34 package body Ada
.Wide_Characters
.Handling
is
36 ---------------------------
37 -- Character_Set_Version --
38 ---------------------------
40 function Character_Set_Version
return String is
43 end Character_Set_Version
;
49 function Is_Alphanumeric
(Item
: Wide_Character) return Boolean is
51 return Is_Letter
(Item
) or else Is_Digit
(Item
);
58 function Is_Control
(Item
: Wide_Character) return Boolean is
60 return Get_Category
(Item
) = Cc
;
67 function Is_Digit
(Item
: Wide_Character) return Boolean
68 renames Ada
.Wide_Characters
.Unicode
.Is_Digit
;
74 function Is_Graphic
(Item
: Wide_Character) return Boolean is
76 return not Is_Non_Graphic
(Item
);
79 --------------------------
80 -- Is_Hexadecimal_Digit --
81 --------------------------
83 function Is_Hexadecimal_Digit
(Item
: Wide_Character) return Boolean is
85 return Is_Digit
(Item
)
86 or else Item
in 'A' .. 'F'
87 or else Item
in 'a' .. 'f';
88 end Is_Hexadecimal_Digit
;
94 function Is_Letter
(Item
: Wide_Character) return Boolean
95 renames Ada
.Wide_Characters
.Unicode
.Is_Letter
;
97 ------------------------
98 -- Is_Line_Terminator --
99 ------------------------
101 function Is_Line_Terminator
(Item
: Wide_Character) return Boolean
102 renames Ada
.Wide_Characters
.Unicode
.Is_Line_Terminator
;
108 function Is_Lower
(Item
: Wide_Character) return Boolean is
110 return Get_Category
(Item
) = Ll
;
117 function Is_Mark
(Item
: Wide_Character) return Boolean
118 renames Ada
.Wide_Characters
.Unicode
.Is_Mark
;
120 ---------------------
121 -- Is_Other_Format --
122 ---------------------
124 function Is_Other_Format
(Item
: Wide_Character) return Boolean
125 renames Ada
.Wide_Characters
.Unicode
.Is_Other
;
127 ------------------------------
128 -- Is_Punctuation_Connector --
129 ------------------------------
131 function Is_Punctuation_Connector
(Item
: Wide_Character) return Boolean
132 renames Ada
.Wide_Characters
.Unicode
.Is_Punctuation
;
138 function Is_Space
(Item
: Wide_Character) return Boolean
139 renames Ada
.Wide_Characters
.Unicode
.Is_Space
;
145 function Is_Special
(Item
: Wide_Character) return Boolean is
147 return Is_Graphic
(Item
) and then not Is_Alphanumeric
(Item
);
154 function Is_Upper
(Item
: Wide_Character) return Boolean is
156 return Get_Category
(Item
) = Lu
;
163 function To_Lower
(Item
: Wide_Character) return Wide_Character
164 renames Ada
.Wide_Characters
.Unicode
.To_Lower_Case
;
166 function To_Lower
(Item
: Wide_String) return Wide_String is
167 Result
: Wide_String (Item
'Range);
170 for J
in Result
'Range loop
171 Result
(J
) := To_Lower
(Item
(J
));
181 function To_Upper
(Item
: Wide_Character) return Wide_Character
182 renames Ada
.Wide_Characters
.Unicode
.To_Upper_Case
;
184 function To_Upper
(Item
: Wide_String) return Wide_String is
185 Result
: Wide_String (Item
'Range);
188 for J
in Result
'Range loop
189 Result
(J
) := To_Upper
(Item
(J
));
195 end Ada
.Wide_Characters
.Handling
;