1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111
|
-------------------------------------------------------------------------------
--
-- This unit is part of the @Asis2@ ASIS secondary library.
--
-- <STRONG>Copyright (c) 2002, 2003 by Thomas Wolf.</STRONG>
-- <BLOCKQUOTE>
-- AdaBrowse is free software; you can redistribute it and/or modify it
-- under the terms of the GNU General Public License as published by the
-- Free Software Foundation; either version 2, or (at your option) any
-- later version. AdaBrowse is distributed in the hope that it will be
-- useful, but <EM>without any warranty</EM>; without even the implied
-- warranty of <EM>merchantability or fitness for a particular purpose.</EM>
-- See the GNU General Public License for more details. You should have
-- received a copy of the GNU General Public License with this distribution,
-- see file "<A HREF="GPL.txt">GPL.txt</A>". If not, write to the Free
-- Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
-- USA.
-- </BLOCKQUOTE>
-- <BLOCKQUOTE>
-- As a special exception from the GPL, if other files instantiate generics
-- from this unit, or you link this unit with other files to produce an
-- executable, this unit does not by itself cause the resulting executable
-- to be covered by the GPL. This exception does not however invalidate any
-- other reasons why the executable file might be covered by the GPL.
-- </BLOCKQUOTE>
--
-- <AUTHOR>
-- Thomas Wolf (TW) <E_MAIL>
-- </AUTHOR>
--
-- <PURPOSE>
-- Commonly useful operations on @Wide_String@.
-- </PURPOSE>
--
-- <HISTORY>
-- 18-JUL-2003 TW Initial version.
-- </HISTORY>
-------------------------------------------------------------------------------
pragma License (Modified_GPL);
with Ada.Strings.Wide_Fixed;
package body Asis2.Text is
package ASF renames Ada.Strings.Wide_Fixed;
package ASM renames Ada.Strings.Wide_Maps;
package ASC renames Ada.Strings.Wide_Maps.Wide_Constants;
----------------------------------------------------------------------------
function To_Lower
(Source : in Wide_String)
return Wide_String
is
begin
return ASF.Translate (Source, ASC.Lower_Case_Map);
end To_Lower;
function To_Upper
(Source : in Wide_String)
return Wide_String
is
begin
return ASF.Translate (Source, ASC.Upper_Case_Map);
end To_Upper;
function To_Basic
(Source : in Wide_String)
return Wide_String
is
begin
return ASF.Translate (Source, ASC.Basic_Map);
end To_Basic;
----------------------------------------------------------------------------
function To_Mixed
(Source : in Wide_String)
return Wide_String
is
Result : Wide_String (1 .. Source'Length);
Alpha_Num : Boolean := False;
J : Natural := 1;
use ASC, ASM;
begin
for I in Source'Range loop
if not Alpha_Num then
Result (J) := Value (Upper_Case_Map, Source (I));
else
Result (J) := Value (Lower_Case_Map, Source (I));
end if;
Alpha_Num := Is_In (Source (I), Alphanumeric_Set);
J := J + 1;
end loop;
return Result;
end To_Mixed;
----------------------------------------------------------------------------
function Trim
(Source : in Wide_String)
return Wide_String
is
begin
return ASF.Trim (Source, White_Space, White_Space);
end Trim;
end Asis2.Text;
|