PR middle-end/66867
[official-gcc.git] / gcc / ada / s-widwch.adb
blob5d9df7bf7bc32ae0a2d17aa7e1e95ee2c44f6df7
1 ------------------------------------------------------------------------------
2 -- --
3 -- GNAT RUN-TIME COMPONENTS --
4 -- --
5 -- S Y S T E M . W I D _ W C H A R --
6 -- --
7 -- B o d y --
8 -- --
9 -- Copyright (C) 1992-2009, Free Software Foundation, Inc. --
10 -- --
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. --
17 -- --
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. --
21 -- --
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/>. --
26 -- --
27 -- GNAT was originally developed by the GNAT team at New York University. --
28 -- Extensive contributions were provided by Ada Core Technologies Inc. --
29 -- --
30 ------------------------------------------------------------------------------
32 package body System.Wid_WChar is
34 --------------------------
35 -- Width_Wide_Character --
36 --------------------------
38 function Width_Wide_Character
39 (Lo, Hi : Wide_Character) return Natural
41 W : Natural;
42 P : Natural;
44 begin
45 W := 0;
46 for C in Lo .. Hi loop
47 P := Wide_Character'Pos (C);
49 -- Here if we find a character in wide character range
50 -- Width is max value (12) for Hex_hhhhhhhh
52 if P > 16#FF# then
53 return 12;
55 -- If we are in character range then use length of character image
57 else
58 declare
59 S : constant String := Character'Image (Character'Val (P));
60 begin
61 W := Natural'Max (W, S'Length);
62 end;
63 end if;
64 end loop;
66 return W;
67 end Width_Wide_Character;
69 -------------------------------
70 -- Width_Wide_Wide_Character --
71 -------------------------------
73 function Width_Wide_Wide_Character
74 (Lo, Hi : Wide_Wide_Character) return Natural
76 W : Natural;
77 P : Natural;
79 begin
80 W := 0;
81 for C in Lo .. Hi loop
82 P := Wide_Wide_Character'Pos (C);
84 -- Here if we find a character in wide wide character range.
85 -- Width is max value (12) for Hex_hhhhhhhh
87 if P > 16#FF# then
88 W := 12;
90 -- If we are in character range then use length of character image
92 else
93 declare
94 S : constant String := Character'Image (Character'Val (P));
95 begin
96 W := Natural'Max (W, S'Length);
97 end;
98 end if;
99 end loop;
101 return W;
102 end Width_Wide_Wide_Character;
104 end System.Wid_WChar;