annotate gcc/ada/namet.adb @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children 84e7813d76e9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 ------------------------------------------------------------------------------
kono
parents:
diff changeset
2 -- --
kono
parents:
diff changeset
3 -- GNAT COMPILER COMPONENTS --
kono
parents:
diff changeset
4 -- --
kono
parents:
diff changeset
5 -- N A M E T --
kono
parents:
diff changeset
6 -- --
kono
parents:
diff changeset
7 -- B o d y --
kono
parents:
diff changeset
8 -- --
kono
parents:
diff changeset
9 -- Copyright (C) 1992-2017, Free Software Foundation, Inc. --
kono
parents:
diff changeset
10 -- --
kono
parents:
diff changeset
11 -- GNAT is free software; you can redistribute it and/or modify it under --
kono
parents:
diff changeset
12 -- terms of the GNU General Public License as published by the Free Soft- --
kono
parents:
diff changeset
13 -- ware Foundation; either version 3, or (at your option) any later ver- --
kono
parents:
diff changeset
14 -- sion. GNAT is distributed in the hope that it will be useful, but WITH- --
kono
parents:
diff changeset
15 -- OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY --
kono
parents:
diff changeset
16 -- or FITNESS FOR A PARTICULAR PURPOSE. --
kono
parents:
diff changeset
17 -- --
kono
parents:
diff changeset
18 -- As a special exception under Section 7 of GPL version 3, you are granted --
kono
parents:
diff changeset
19 -- additional permissions described in the GCC Runtime Library Exception, --
kono
parents:
diff changeset
20 -- version 3.1, as published by the Free Software Foundation. --
kono
parents:
diff changeset
21 -- --
kono
parents:
diff changeset
22 -- You should have received a copy of the GNU General Public License and --
kono
parents:
diff changeset
23 -- a copy of the GCC Runtime Library Exception along with this program; --
kono
parents:
diff changeset
24 -- see the files COPYING3 and COPYING.RUNTIME respectively. If not, see --
kono
parents:
diff changeset
25 -- <http://www.gnu.org/licenses/>. --
kono
parents:
diff changeset
26 -- --
kono
parents:
diff changeset
27 -- GNAT was originally developed by the GNAT team at New York University. --
kono
parents:
diff changeset
28 -- Extensive contributions were provided by Ada Core Technologies Inc. --
kono
parents:
diff changeset
29 -- --
kono
parents:
diff changeset
30 ------------------------------------------------------------------------------
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 -- WARNING: There is a C version of this package. Any changes to this
kono
parents:
diff changeset
33 -- source file must be properly reflected in the C header file namet.h
kono
parents:
diff changeset
34 -- which is created manually from namet.ads and namet.adb.
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 with Debug; use Debug;
kono
parents:
diff changeset
37 with Opt; use Opt;
kono
parents:
diff changeset
38 with Output; use Output;
kono
parents:
diff changeset
39 with System; use System;
kono
parents:
diff changeset
40 with Tree_IO; use Tree_IO;
kono
parents:
diff changeset
41 with Widechar;
kono
parents:
diff changeset
42
kono
parents:
diff changeset
43 with Interfaces; use Interfaces;
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 package body Namet is
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 Name_Chars_Reserve : constant := 5000;
kono
parents:
diff changeset
48 Name_Entries_Reserve : constant := 100;
kono
parents:
diff changeset
49 -- The names table is locked during gigi processing, since gigi assumes
kono
parents:
diff changeset
50 -- that the table does not move. After returning from gigi, the names
kono
parents:
diff changeset
51 -- table is unlocked again, since writing library file information needs
kono
parents:
diff changeset
52 -- to generate some extra names. To avoid the inefficiency of always
kono
parents:
diff changeset
53 -- reallocating during this second unlocked phase, we reserve a bit of
kono
parents:
diff changeset
54 -- extra space before doing the release call.
kono
parents:
diff changeset
55
kono
parents:
diff changeset
56 Hash_Num : constant Int := 2**16;
kono
parents:
diff changeset
57 -- Number of headers in the hash table. Current hash algorithm is closely
kono
parents:
diff changeset
58 -- tailored to this choice, so it can only be changed if a corresponding
kono
parents:
diff changeset
59 -- change is made to the hash algorithm.
kono
parents:
diff changeset
60
kono
parents:
diff changeset
61 Hash_Max : constant Int := Hash_Num - 1;
kono
parents:
diff changeset
62 -- Indexes in the hash header table run from 0 to Hash_Num - 1
kono
parents:
diff changeset
63
kono
parents:
diff changeset
64 subtype Hash_Index_Type is Int range 0 .. Hash_Max;
kono
parents:
diff changeset
65 -- Range of hash index values
kono
parents:
diff changeset
66
kono
parents:
diff changeset
67 Hash_Table : array (Hash_Index_Type) of Name_Id;
kono
parents:
diff changeset
68 -- The hash table is used to locate existing entries in the names table.
kono
parents:
diff changeset
69 -- The entries point to the first names table entry whose hash value
kono
parents:
diff changeset
70 -- matches the hash code. Then subsequent names table entries with the
kono
parents:
diff changeset
71 -- same hash code value are linked through the Hash_Link fields.
kono
parents:
diff changeset
72
kono
parents:
diff changeset
73 -----------------------
kono
parents:
diff changeset
74 -- Local Subprograms --
kono
parents:
diff changeset
75 -----------------------
kono
parents:
diff changeset
76
kono
parents:
diff changeset
77 function Hash (Buf : Bounded_String) return Hash_Index_Type;
kono
parents:
diff changeset
78 pragma Inline (Hash);
kono
parents:
diff changeset
79 -- Compute hash code for name stored in Buf
kono
parents:
diff changeset
80
kono
parents:
diff changeset
81 procedure Strip_Qualification_And_Suffixes (Buf : in out Bounded_String);
kono
parents:
diff changeset
82 -- Given an encoded entity name in Buf, remove package body
kono
parents:
diff changeset
83 -- suffix as described for Strip_Package_Body_Suffix, and also remove
kono
parents:
diff changeset
84 -- all qualification, i.e. names followed by two underscores.
kono
parents:
diff changeset
85
kono
parents:
diff changeset
86 -----------------------------
kono
parents:
diff changeset
87 -- Add_Char_To_Name_Buffer --
kono
parents:
diff changeset
88 -----------------------------
kono
parents:
diff changeset
89
kono
parents:
diff changeset
90 procedure Add_Char_To_Name_Buffer (C : Character) is
kono
parents:
diff changeset
91 begin
kono
parents:
diff changeset
92 Append (Global_Name_Buffer, C);
kono
parents:
diff changeset
93 end Add_Char_To_Name_Buffer;
kono
parents:
diff changeset
94
kono
parents:
diff changeset
95 ----------------------------
kono
parents:
diff changeset
96 -- Add_Nat_To_Name_Buffer --
kono
parents:
diff changeset
97 ----------------------------
kono
parents:
diff changeset
98
kono
parents:
diff changeset
99 procedure Add_Nat_To_Name_Buffer (V : Nat) is
kono
parents:
diff changeset
100 begin
kono
parents:
diff changeset
101 Append (Global_Name_Buffer, V);
kono
parents:
diff changeset
102 end Add_Nat_To_Name_Buffer;
kono
parents:
diff changeset
103
kono
parents:
diff changeset
104 ----------------------------
kono
parents:
diff changeset
105 -- Add_Str_To_Name_Buffer --
kono
parents:
diff changeset
106 ----------------------------
kono
parents:
diff changeset
107
kono
parents:
diff changeset
108 procedure Add_Str_To_Name_Buffer (S : String) is
kono
parents:
diff changeset
109 begin
kono
parents:
diff changeset
110 Append (Global_Name_Buffer, S);
kono
parents:
diff changeset
111 end Add_Str_To_Name_Buffer;
kono
parents:
diff changeset
112
kono
parents:
diff changeset
113 ------------
kono
parents:
diff changeset
114 -- Append --
kono
parents:
diff changeset
115 ------------
kono
parents:
diff changeset
116
kono
parents:
diff changeset
117 procedure Append (Buf : in out Bounded_String; C : Character) is
kono
parents:
diff changeset
118 begin
kono
parents:
diff changeset
119 Buf.Length := Buf.Length + 1;
kono
parents:
diff changeset
120
kono
parents:
diff changeset
121 if Buf.Length > Buf.Chars'Last then
kono
parents:
diff changeset
122 Write_Str ("Name buffer overflow; Max_Length = ");
kono
parents:
diff changeset
123 Write_Int (Int (Buf.Max_Length));
kono
parents:
diff changeset
124 Write_Line ("");
kono
parents:
diff changeset
125 raise Program_Error;
kono
parents:
diff changeset
126 end if;
kono
parents:
diff changeset
127
kono
parents:
diff changeset
128 Buf.Chars (Buf.Length) := C;
kono
parents:
diff changeset
129 end Append;
kono
parents:
diff changeset
130
kono
parents:
diff changeset
131 procedure Append (Buf : in out Bounded_String; V : Nat) is
kono
parents:
diff changeset
132 begin
kono
parents:
diff changeset
133 if V >= 10 then
kono
parents:
diff changeset
134 Append (Buf, V / 10);
kono
parents:
diff changeset
135 end if;
kono
parents:
diff changeset
136
kono
parents:
diff changeset
137 Append (Buf, Character'Val (Character'Pos ('0') + V rem 10));
kono
parents:
diff changeset
138 end Append;
kono
parents:
diff changeset
139
kono
parents:
diff changeset
140 procedure Append (Buf : in out Bounded_String; S : String) is
kono
parents:
diff changeset
141 First : constant Natural := Buf.Length + 1;
kono
parents:
diff changeset
142 begin
kono
parents:
diff changeset
143 Buf.Length := Buf.Length + S'Length;
kono
parents:
diff changeset
144
kono
parents:
diff changeset
145 if Buf.Length > Buf.Chars'Last then
kono
parents:
diff changeset
146 Write_Str ("Name buffer overflow; Max_Length = ");
kono
parents:
diff changeset
147 Write_Int (Int (Buf.Max_Length));
kono
parents:
diff changeset
148 Write_Line ("");
kono
parents:
diff changeset
149 raise Program_Error;
kono
parents:
diff changeset
150 end if;
kono
parents:
diff changeset
151
kono
parents:
diff changeset
152 Buf.Chars (First .. Buf.Length) := S;
kono
parents:
diff changeset
153 -- A loop calling Append(Character) would be cleaner, but this slice
kono
parents:
diff changeset
154 -- assignment is substantially faster.
kono
parents:
diff changeset
155 end Append;
kono
parents:
diff changeset
156
kono
parents:
diff changeset
157 procedure Append (Buf : in out Bounded_String; Buf2 : Bounded_String) is
kono
parents:
diff changeset
158 begin
kono
parents:
diff changeset
159 Append (Buf, Buf2.Chars (1 .. Buf2.Length));
kono
parents:
diff changeset
160 end Append;
kono
parents:
diff changeset
161
kono
parents:
diff changeset
162 procedure Append (Buf : in out Bounded_String; Id : Name_Id) is
kono
parents:
diff changeset
163 pragma Assert (Id in Name_Entries.First .. Name_Entries.Last);
kono
parents:
diff changeset
164
kono
parents:
diff changeset
165 Index : constant Int := Name_Entries.Table (Id).Name_Chars_Index;
kono
parents:
diff changeset
166 Len : constant Short := Name_Entries.Table (Id).Name_Len;
kono
parents:
diff changeset
167 Chars : Name_Chars.Table_Type renames
kono
parents:
diff changeset
168 Name_Chars.Table (Index + 1 .. Index + Int (Len));
kono
parents:
diff changeset
169 begin
kono
parents:
diff changeset
170 Append (Buf, String (Chars));
kono
parents:
diff changeset
171 end Append;
kono
parents:
diff changeset
172
kono
parents:
diff changeset
173 --------------------
kono
parents:
diff changeset
174 -- Append_Decoded --
kono
parents:
diff changeset
175 --------------------
kono
parents:
diff changeset
176
kono
parents:
diff changeset
177 procedure Append_Decoded (Buf : in out Bounded_String; Id : Name_Id) is
kono
parents:
diff changeset
178 C : Character;
kono
parents:
diff changeset
179 P : Natural;
kono
parents:
diff changeset
180 Temp : Bounded_String;
kono
parents:
diff changeset
181
kono
parents:
diff changeset
182 begin
kono
parents:
diff changeset
183 Append (Temp, Id);
kono
parents:
diff changeset
184
kono
parents:
diff changeset
185 -- Skip scan if we already know there are no encodings
kono
parents:
diff changeset
186
kono
parents:
diff changeset
187 if Name_Entries.Table (Id).Name_Has_No_Encodings then
kono
parents:
diff changeset
188 goto Done;
kono
parents:
diff changeset
189 end if;
kono
parents:
diff changeset
190
kono
parents:
diff changeset
191 -- Quick loop to see if there is anything special to do
kono
parents:
diff changeset
192
kono
parents:
diff changeset
193 P := 1;
kono
parents:
diff changeset
194 loop
kono
parents:
diff changeset
195 if P = Temp.Length then
kono
parents:
diff changeset
196 Name_Entries.Table (Id).Name_Has_No_Encodings := True;
kono
parents:
diff changeset
197 goto Done;
kono
parents:
diff changeset
198
kono
parents:
diff changeset
199 else
kono
parents:
diff changeset
200 C := Temp.Chars (P);
kono
parents:
diff changeset
201
kono
parents:
diff changeset
202 exit when
kono
parents:
diff changeset
203 C = 'U' or else
kono
parents:
diff changeset
204 C = 'W' or else
kono
parents:
diff changeset
205 C = 'Q' or else
kono
parents:
diff changeset
206 C = 'O';
kono
parents:
diff changeset
207
kono
parents:
diff changeset
208 P := P + 1;
kono
parents:
diff changeset
209 end if;
kono
parents:
diff changeset
210 end loop;
kono
parents:
diff changeset
211
kono
parents:
diff changeset
212 -- Here we have at least some encoding that we must decode
kono
parents:
diff changeset
213
kono
parents:
diff changeset
214 Decode : declare
kono
parents:
diff changeset
215 New_Len : Natural;
kono
parents:
diff changeset
216 Old : Positive;
kono
parents:
diff changeset
217 New_Buf : String (1 .. Temp.Chars'Last);
kono
parents:
diff changeset
218
kono
parents:
diff changeset
219 procedure Copy_One_Character;
kono
parents:
diff changeset
220 -- Copy a character from Temp.Chars to New_Buf. Includes case
kono
parents:
diff changeset
221 -- of copying a Uhh,Whhhh,WWhhhhhhhh sequence and decoding it.
kono
parents:
diff changeset
222
kono
parents:
diff changeset
223 function Hex (N : Natural) return Word;
kono
parents:
diff changeset
224 -- Scans past N digits using Old pointer and returns hex value
kono
parents:
diff changeset
225
kono
parents:
diff changeset
226 procedure Insert_Character (C : Character);
kono
parents:
diff changeset
227 -- Insert a new character into output decoded name
kono
parents:
diff changeset
228
kono
parents:
diff changeset
229 ------------------------
kono
parents:
diff changeset
230 -- Copy_One_Character --
kono
parents:
diff changeset
231 ------------------------
kono
parents:
diff changeset
232
kono
parents:
diff changeset
233 procedure Copy_One_Character is
kono
parents:
diff changeset
234 C : Character;
kono
parents:
diff changeset
235
kono
parents:
diff changeset
236 begin
kono
parents:
diff changeset
237 C := Temp.Chars (Old);
kono
parents:
diff changeset
238
kono
parents:
diff changeset
239 -- U (upper half insertion case)
kono
parents:
diff changeset
240
kono
parents:
diff changeset
241 if C = 'U'
kono
parents:
diff changeset
242 and then Old < Temp.Length
kono
parents:
diff changeset
243 and then Temp.Chars (Old + 1) not in 'A' .. 'Z'
kono
parents:
diff changeset
244 and then Temp.Chars (Old + 1) /= '_'
kono
parents:
diff changeset
245 then
kono
parents:
diff changeset
246 Old := Old + 1;
kono
parents:
diff changeset
247
kono
parents:
diff changeset
248 -- If we have upper half encoding, then we have to set an
kono
parents:
diff changeset
249 -- appropriate wide character sequence for this character.
kono
parents:
diff changeset
250
kono
parents:
diff changeset
251 if Upper_Half_Encoding then
kono
parents:
diff changeset
252 Widechar.Set_Wide (Char_Code (Hex (2)), New_Buf, New_Len);
kono
parents:
diff changeset
253
kono
parents:
diff changeset
254 -- For other encoding methods, upper half characters can
kono
parents:
diff changeset
255 -- simply use their normal representation.
kono
parents:
diff changeset
256
kono
parents:
diff changeset
257 else
kono
parents:
diff changeset
258 Insert_Character (Character'Val (Hex (2)));
kono
parents:
diff changeset
259 end if;
kono
parents:
diff changeset
260
kono
parents:
diff changeset
261 -- WW (wide wide character insertion)
kono
parents:
diff changeset
262
kono
parents:
diff changeset
263 elsif C = 'W'
kono
parents:
diff changeset
264 and then Old < Temp.Length
kono
parents:
diff changeset
265 and then Temp.Chars (Old + 1) = 'W'
kono
parents:
diff changeset
266 then
kono
parents:
diff changeset
267 Old := Old + 2;
kono
parents:
diff changeset
268 Widechar.Set_Wide (Char_Code (Hex (8)), New_Buf, New_Len);
kono
parents:
diff changeset
269
kono
parents:
diff changeset
270 -- W (wide character insertion)
kono
parents:
diff changeset
271
kono
parents:
diff changeset
272 elsif C = 'W'
kono
parents:
diff changeset
273 and then Old < Temp.Length
kono
parents:
diff changeset
274 and then Temp.Chars (Old + 1) not in 'A' .. 'Z'
kono
parents:
diff changeset
275 and then Temp.Chars (Old + 1) /= '_'
kono
parents:
diff changeset
276 then
kono
parents:
diff changeset
277 Old := Old + 1;
kono
parents:
diff changeset
278 Widechar.Set_Wide (Char_Code (Hex (4)), New_Buf, New_Len);
kono
parents:
diff changeset
279
kono
parents:
diff changeset
280 -- Any other character is copied unchanged
kono
parents:
diff changeset
281
kono
parents:
diff changeset
282 else
kono
parents:
diff changeset
283 Insert_Character (C);
kono
parents:
diff changeset
284 Old := Old + 1;
kono
parents:
diff changeset
285 end if;
kono
parents:
diff changeset
286 end Copy_One_Character;
kono
parents:
diff changeset
287
kono
parents:
diff changeset
288 ---------
kono
parents:
diff changeset
289 -- Hex --
kono
parents:
diff changeset
290 ---------
kono
parents:
diff changeset
291
kono
parents:
diff changeset
292 function Hex (N : Natural) return Word is
kono
parents:
diff changeset
293 T : Word := 0;
kono
parents:
diff changeset
294 C : Character;
kono
parents:
diff changeset
295
kono
parents:
diff changeset
296 begin
kono
parents:
diff changeset
297 for J in 1 .. N loop
kono
parents:
diff changeset
298 C := Temp.Chars (Old);
kono
parents:
diff changeset
299 Old := Old + 1;
kono
parents:
diff changeset
300
kono
parents:
diff changeset
301 pragma Assert (C in '0' .. '9' or else C in 'a' .. 'f');
kono
parents:
diff changeset
302
kono
parents:
diff changeset
303 if C <= '9' then
kono
parents:
diff changeset
304 T := 16 * T + Character'Pos (C) - Character'Pos ('0');
kono
parents:
diff changeset
305 else -- C in 'a' .. 'f'
kono
parents:
diff changeset
306 T := 16 * T + Character'Pos (C) - (Character'Pos ('a') - 10);
kono
parents:
diff changeset
307 end if;
kono
parents:
diff changeset
308 end loop;
kono
parents:
diff changeset
309
kono
parents:
diff changeset
310 return T;
kono
parents:
diff changeset
311 end Hex;
kono
parents:
diff changeset
312
kono
parents:
diff changeset
313 ----------------------
kono
parents:
diff changeset
314 -- Insert_Character --
kono
parents:
diff changeset
315 ----------------------
kono
parents:
diff changeset
316
kono
parents:
diff changeset
317 procedure Insert_Character (C : Character) is
kono
parents:
diff changeset
318 begin
kono
parents:
diff changeset
319 New_Len := New_Len + 1;
kono
parents:
diff changeset
320 New_Buf (New_Len) := C;
kono
parents:
diff changeset
321 end Insert_Character;
kono
parents:
diff changeset
322
kono
parents:
diff changeset
323 -- Start of processing for Decode
kono
parents:
diff changeset
324
kono
parents:
diff changeset
325 begin
kono
parents:
diff changeset
326 New_Len := 0;
kono
parents:
diff changeset
327 Old := 1;
kono
parents:
diff changeset
328
kono
parents:
diff changeset
329 -- Loop through characters of name
kono
parents:
diff changeset
330
kono
parents:
diff changeset
331 while Old <= Temp.Length loop
kono
parents:
diff changeset
332
kono
parents:
diff changeset
333 -- Case of character literal, put apostrophes around character
kono
parents:
diff changeset
334
kono
parents:
diff changeset
335 if Temp.Chars (Old) = 'Q'
kono
parents:
diff changeset
336 and then Old < Temp.Length
kono
parents:
diff changeset
337 then
kono
parents:
diff changeset
338 Old := Old + 1;
kono
parents:
diff changeset
339 Insert_Character (''');
kono
parents:
diff changeset
340 Copy_One_Character;
kono
parents:
diff changeset
341 Insert_Character (''');
kono
parents:
diff changeset
342
kono
parents:
diff changeset
343 -- Case of operator name
kono
parents:
diff changeset
344
kono
parents:
diff changeset
345 elsif Temp.Chars (Old) = 'O'
kono
parents:
diff changeset
346 and then Old < Temp.Length
kono
parents:
diff changeset
347 and then Temp.Chars (Old + 1) not in 'A' .. 'Z'
kono
parents:
diff changeset
348 and then Temp.Chars (Old + 1) /= '_'
kono
parents:
diff changeset
349 then
kono
parents:
diff changeset
350 Old := Old + 1;
kono
parents:
diff changeset
351
kono
parents:
diff changeset
352 declare
kono
parents:
diff changeset
353 -- This table maps the 2nd and 3rd characters of the name
kono
parents:
diff changeset
354 -- into the required output. Two blanks means leave the
kono
parents:
diff changeset
355 -- name alone
kono
parents:
diff changeset
356
kono
parents:
diff changeset
357 Map : constant String :=
kono
parents:
diff changeset
358 "ab " & -- Oabs => "abs"
kono
parents:
diff changeset
359 "ad+ " & -- Oadd => "+"
kono
parents:
diff changeset
360 "an " & -- Oand => "and"
kono
parents:
diff changeset
361 "co& " & -- Oconcat => "&"
kono
parents:
diff changeset
362 "di/ " & -- Odivide => "/"
kono
parents:
diff changeset
363 "eq= " & -- Oeq => "="
kono
parents:
diff changeset
364 "ex**" & -- Oexpon => "**"
kono
parents:
diff changeset
365 "gt> " & -- Ogt => ">"
kono
parents:
diff changeset
366 "ge>=" & -- Oge => ">="
kono
parents:
diff changeset
367 "le<=" & -- Ole => "<="
kono
parents:
diff changeset
368 "lt< " & -- Olt => "<"
kono
parents:
diff changeset
369 "mo " & -- Omod => "mod"
kono
parents:
diff changeset
370 "mu* " & -- Omutliply => "*"
kono
parents:
diff changeset
371 "ne/=" & -- One => "/="
kono
parents:
diff changeset
372 "no " & -- Onot => "not"
kono
parents:
diff changeset
373 "or " & -- Oor => "or"
kono
parents:
diff changeset
374 "re " & -- Orem => "rem"
kono
parents:
diff changeset
375 "su- " & -- Osubtract => "-"
kono
parents:
diff changeset
376 "xo "; -- Oxor => "xor"
kono
parents:
diff changeset
377
kono
parents:
diff changeset
378 J : Integer;
kono
parents:
diff changeset
379
kono
parents:
diff changeset
380 begin
kono
parents:
diff changeset
381 Insert_Character ('"');
kono
parents:
diff changeset
382
kono
parents:
diff changeset
383 -- Search the map. Note that this loop must terminate, if
kono
parents:
diff changeset
384 -- not we have some kind of internal error, and a constraint
kono
parents:
diff changeset
385 -- error may be raised.
kono
parents:
diff changeset
386
kono
parents:
diff changeset
387 J := Map'First;
kono
parents:
diff changeset
388 loop
kono
parents:
diff changeset
389 exit when Temp.Chars (Old) = Map (J)
kono
parents:
diff changeset
390 and then Temp.Chars (Old + 1) = Map (J + 1);
kono
parents:
diff changeset
391 J := J + 4;
kono
parents:
diff changeset
392 end loop;
kono
parents:
diff changeset
393
kono
parents:
diff changeset
394 -- Special operator name
kono
parents:
diff changeset
395
kono
parents:
diff changeset
396 if Map (J + 2) /= ' ' then
kono
parents:
diff changeset
397 Insert_Character (Map (J + 2));
kono
parents:
diff changeset
398
kono
parents:
diff changeset
399 if Map (J + 3) /= ' ' then
kono
parents:
diff changeset
400 Insert_Character (Map (J + 3));
kono
parents:
diff changeset
401 end if;
kono
parents:
diff changeset
402
kono
parents:
diff changeset
403 Insert_Character ('"');
kono
parents:
diff changeset
404
kono
parents:
diff changeset
405 -- Skip past original operator name in input
kono
parents:
diff changeset
406
kono
parents:
diff changeset
407 while Old <= Temp.Length
kono
parents:
diff changeset
408 and then Temp.Chars (Old) in 'a' .. 'z'
kono
parents:
diff changeset
409 loop
kono
parents:
diff changeset
410 Old := Old + 1;
kono
parents:
diff changeset
411 end loop;
kono
parents:
diff changeset
412
kono
parents:
diff changeset
413 -- For other operator names, leave them in lower case,
kono
parents:
diff changeset
414 -- surrounded by apostrophes
kono
parents:
diff changeset
415
kono
parents:
diff changeset
416 else
kono
parents:
diff changeset
417 -- Copy original operator name from input to output
kono
parents:
diff changeset
418
kono
parents:
diff changeset
419 while Old <= Temp.Length
kono
parents:
diff changeset
420 and then Temp.Chars (Old) in 'a' .. 'z'
kono
parents:
diff changeset
421 loop
kono
parents:
diff changeset
422 Copy_One_Character;
kono
parents:
diff changeset
423 end loop;
kono
parents:
diff changeset
424
kono
parents:
diff changeset
425 Insert_Character ('"');
kono
parents:
diff changeset
426 end if;
kono
parents:
diff changeset
427 end;
kono
parents:
diff changeset
428
kono
parents:
diff changeset
429 -- Else copy one character and keep going
kono
parents:
diff changeset
430
kono
parents:
diff changeset
431 else
kono
parents:
diff changeset
432 Copy_One_Character;
kono
parents:
diff changeset
433 end if;
kono
parents:
diff changeset
434 end loop;
kono
parents:
diff changeset
435
kono
parents:
diff changeset
436 -- Copy new buffer as result
kono
parents:
diff changeset
437
kono
parents:
diff changeset
438 Temp.Length := New_Len;
kono
parents:
diff changeset
439 Temp.Chars (1 .. New_Len) := New_Buf (1 .. New_Len);
kono
parents:
diff changeset
440 end Decode;
kono
parents:
diff changeset
441
kono
parents:
diff changeset
442 <<Done>>
kono
parents:
diff changeset
443 Append (Buf, Temp);
kono
parents:
diff changeset
444 end Append_Decoded;
kono
parents:
diff changeset
445
kono
parents:
diff changeset
446 ----------------------------------
kono
parents:
diff changeset
447 -- Append_Decoded_With_Brackets --
kono
parents:
diff changeset
448 ----------------------------------
kono
parents:
diff changeset
449
kono
parents:
diff changeset
450 procedure Append_Decoded_With_Brackets
kono
parents:
diff changeset
451 (Buf : in out Bounded_String;
kono
parents:
diff changeset
452 Id : Name_Id)
kono
parents:
diff changeset
453 is
kono
parents:
diff changeset
454 P : Natural;
kono
parents:
diff changeset
455
kono
parents:
diff changeset
456 begin
kono
parents:
diff changeset
457 -- Case of operator name, normal decoding is fine
kono
parents:
diff changeset
458
kono
parents:
diff changeset
459 if Buf.Chars (1) = 'O' then
kono
parents:
diff changeset
460 Append_Decoded (Buf, Id);
kono
parents:
diff changeset
461
kono
parents:
diff changeset
462 -- For character literals, normal decoding is fine
kono
parents:
diff changeset
463
kono
parents:
diff changeset
464 elsif Buf.Chars (1) = 'Q' then
kono
parents:
diff changeset
465 Append_Decoded (Buf, Id);
kono
parents:
diff changeset
466
kono
parents:
diff changeset
467 -- Only remaining issue is U/W/WW sequences
kono
parents:
diff changeset
468
kono
parents:
diff changeset
469 else
kono
parents:
diff changeset
470 declare
kono
parents:
diff changeset
471 Temp : Bounded_String;
kono
parents:
diff changeset
472 begin
kono
parents:
diff changeset
473 Append (Temp, Id);
kono
parents:
diff changeset
474
kono
parents:
diff changeset
475 P := 1;
kono
parents:
diff changeset
476 while P < Temp.Length loop
kono
parents:
diff changeset
477 if Temp.Chars (P + 1) in 'A' .. 'Z' then
kono
parents:
diff changeset
478 P := P + 1;
kono
parents:
diff changeset
479
kono
parents:
diff changeset
480 -- Uhh encoding
kono
parents:
diff changeset
481
kono
parents:
diff changeset
482 elsif Temp.Chars (P) = 'U' then
kono
parents:
diff changeset
483 for J in reverse P + 3 .. P + Temp.Length loop
kono
parents:
diff changeset
484 Temp.Chars (J + 3) := Temp.Chars (J);
kono
parents:
diff changeset
485 end loop;
kono
parents:
diff changeset
486
kono
parents:
diff changeset
487 Temp.Length := Temp.Length + 3;
kono
parents:
diff changeset
488 Temp.Chars (P + 3) := Temp.Chars (P + 2);
kono
parents:
diff changeset
489 Temp.Chars (P + 2) := Temp.Chars (P + 1);
kono
parents:
diff changeset
490 Temp.Chars (P) := '[';
kono
parents:
diff changeset
491 Temp.Chars (P + 1) := '"';
kono
parents:
diff changeset
492 Temp.Chars (P + 4) := '"';
kono
parents:
diff changeset
493 Temp.Chars (P + 5) := ']';
kono
parents:
diff changeset
494 P := P + 6;
kono
parents:
diff changeset
495
kono
parents:
diff changeset
496 -- WWhhhhhhhh encoding
kono
parents:
diff changeset
497
kono
parents:
diff changeset
498 elsif Temp.Chars (P) = 'W'
kono
parents:
diff changeset
499 and then P + 9 <= Temp.Length
kono
parents:
diff changeset
500 and then Temp.Chars (P + 1) = 'W'
kono
parents:
diff changeset
501 and then Temp.Chars (P + 2) not in 'A' .. 'Z'
kono
parents:
diff changeset
502 and then Temp.Chars (P + 2) /= '_'
kono
parents:
diff changeset
503 then
kono
parents:
diff changeset
504 Temp.Chars (P + 12 .. Temp.Length + 2) :=
kono
parents:
diff changeset
505 Temp.Chars (P + 10 .. Temp.Length);
kono
parents:
diff changeset
506 Temp.Chars (P) := '[';
kono
parents:
diff changeset
507 Temp.Chars (P + 1) := '"';
kono
parents:
diff changeset
508 Temp.Chars (P + 10) := '"';
kono
parents:
diff changeset
509 Temp.Chars (P + 11) := ']';
kono
parents:
diff changeset
510 Temp.Length := Temp.Length + 2;
kono
parents:
diff changeset
511 P := P + 12;
kono
parents:
diff changeset
512
kono
parents:
diff changeset
513 -- Whhhh encoding
kono
parents:
diff changeset
514
kono
parents:
diff changeset
515 elsif Temp.Chars (P) = 'W'
kono
parents:
diff changeset
516 and then P < Temp.Length
kono
parents:
diff changeset
517 and then Temp.Chars (P + 1) not in 'A' .. 'Z'
kono
parents:
diff changeset
518 and then Temp.Chars (P + 1) /= '_'
kono
parents:
diff changeset
519 then
kono
parents:
diff changeset
520 Temp.Chars (P + 8 .. P + Temp.Length + 3) :=
kono
parents:
diff changeset
521 Temp.Chars (P + 5 .. Temp.Length);
kono
parents:
diff changeset
522 Temp.Chars (P + 2 .. P + 5) := Temp.Chars (P + 1 .. P + 4);
kono
parents:
diff changeset
523 Temp.Chars (P) := '[';
kono
parents:
diff changeset
524 Temp.Chars (P + 1) := '"';
kono
parents:
diff changeset
525 Temp.Chars (P + 6) := '"';
kono
parents:
diff changeset
526 Temp.Chars (P + 7) := ']';
kono
parents:
diff changeset
527 Temp.Length := Temp.Length + 3;
kono
parents:
diff changeset
528 P := P + 8;
kono
parents:
diff changeset
529
kono
parents:
diff changeset
530 else
kono
parents:
diff changeset
531 P := P + 1;
kono
parents:
diff changeset
532 end if;
kono
parents:
diff changeset
533 end loop;
kono
parents:
diff changeset
534
kono
parents:
diff changeset
535 Append (Buf, Temp);
kono
parents:
diff changeset
536 end;
kono
parents:
diff changeset
537 end if;
kono
parents:
diff changeset
538 end Append_Decoded_With_Brackets;
kono
parents:
diff changeset
539
kono
parents:
diff changeset
540 --------------------
kono
parents:
diff changeset
541 -- Append_Encoded --
kono
parents:
diff changeset
542 --------------------
kono
parents:
diff changeset
543
kono
parents:
diff changeset
544 procedure Append_Encoded (Buf : in out Bounded_String; C : Char_Code) is
kono
parents:
diff changeset
545 procedure Set_Hex_Chars (C : Char_Code);
kono
parents:
diff changeset
546 -- Stores given value, which is in the range 0 .. 255, as two hex
kono
parents:
diff changeset
547 -- digits (using lower case a-f) in Buf.Chars, incrementing Buf.Length.
kono
parents:
diff changeset
548
kono
parents:
diff changeset
549 -------------------
kono
parents:
diff changeset
550 -- Set_Hex_Chars --
kono
parents:
diff changeset
551 -------------------
kono
parents:
diff changeset
552
kono
parents:
diff changeset
553 procedure Set_Hex_Chars (C : Char_Code) is
kono
parents:
diff changeset
554 Hexd : constant String := "0123456789abcdef";
kono
parents:
diff changeset
555 N : constant Natural := Natural (C);
kono
parents:
diff changeset
556 begin
kono
parents:
diff changeset
557 Buf.Chars (Buf.Length + 1) := Hexd (N / 16 + 1);
kono
parents:
diff changeset
558 Buf.Chars (Buf.Length + 2) := Hexd (N mod 16 + 1);
kono
parents:
diff changeset
559 Buf.Length := Buf.Length + 2;
kono
parents:
diff changeset
560 end Set_Hex_Chars;
kono
parents:
diff changeset
561
kono
parents:
diff changeset
562 -- Start of processing for Append_Encoded
kono
parents:
diff changeset
563
kono
parents:
diff changeset
564 begin
kono
parents:
diff changeset
565 Buf.Length := Buf.Length + 1;
kono
parents:
diff changeset
566
kono
parents:
diff changeset
567 if In_Character_Range (C) then
kono
parents:
diff changeset
568 declare
kono
parents:
diff changeset
569 CC : constant Character := Get_Character (C);
kono
parents:
diff changeset
570 begin
kono
parents:
diff changeset
571 if CC in 'a' .. 'z' or else CC in '0' .. '9' then
kono
parents:
diff changeset
572 Buf.Chars (Buf.Length) := CC;
kono
parents:
diff changeset
573 else
kono
parents:
diff changeset
574 Buf.Chars (Buf.Length) := 'U';
kono
parents:
diff changeset
575 Set_Hex_Chars (C);
kono
parents:
diff changeset
576 end if;
kono
parents:
diff changeset
577 end;
kono
parents:
diff changeset
578
kono
parents:
diff changeset
579 elsif In_Wide_Character_Range (C) then
kono
parents:
diff changeset
580 Buf.Chars (Buf.Length) := 'W';
kono
parents:
diff changeset
581 Set_Hex_Chars (C / 256);
kono
parents:
diff changeset
582 Set_Hex_Chars (C mod 256);
kono
parents:
diff changeset
583
kono
parents:
diff changeset
584 else
kono
parents:
diff changeset
585 Buf.Chars (Buf.Length) := 'W';
kono
parents:
diff changeset
586 Buf.Length := Buf.Length + 1;
kono
parents:
diff changeset
587 Buf.Chars (Buf.Length) := 'W';
kono
parents:
diff changeset
588 Set_Hex_Chars (C / 2 ** 24);
kono
parents:
diff changeset
589 Set_Hex_Chars ((C / 2 ** 16) mod 256);
kono
parents:
diff changeset
590 Set_Hex_Chars ((C / 256) mod 256);
kono
parents:
diff changeset
591 Set_Hex_Chars (C mod 256);
kono
parents:
diff changeset
592 end if;
kono
parents:
diff changeset
593 end Append_Encoded;
kono
parents:
diff changeset
594
kono
parents:
diff changeset
595 ------------------------
kono
parents:
diff changeset
596 -- Append_Unqualified --
kono
parents:
diff changeset
597 ------------------------
kono
parents:
diff changeset
598
kono
parents:
diff changeset
599 procedure Append_Unqualified (Buf : in out Bounded_String; Id : Name_Id) is
kono
parents:
diff changeset
600 Temp : Bounded_String;
kono
parents:
diff changeset
601 begin
kono
parents:
diff changeset
602 Append (Temp, Id);
kono
parents:
diff changeset
603 Strip_Qualification_And_Suffixes (Temp);
kono
parents:
diff changeset
604 Append (Buf, Temp);
kono
parents:
diff changeset
605 end Append_Unqualified;
kono
parents:
diff changeset
606
kono
parents:
diff changeset
607 --------------------------------
kono
parents:
diff changeset
608 -- Append_Unqualified_Decoded --
kono
parents:
diff changeset
609 --------------------------------
kono
parents:
diff changeset
610
kono
parents:
diff changeset
611 procedure Append_Unqualified_Decoded
kono
parents:
diff changeset
612 (Buf : in out Bounded_String;
kono
parents:
diff changeset
613 Id : Name_Id)
kono
parents:
diff changeset
614 is
kono
parents:
diff changeset
615 Temp : Bounded_String;
kono
parents:
diff changeset
616 begin
kono
parents:
diff changeset
617 Append_Decoded (Temp, Id);
kono
parents:
diff changeset
618 Strip_Qualification_And_Suffixes (Temp);
kono
parents:
diff changeset
619 Append (Buf, Temp);
kono
parents:
diff changeset
620 end Append_Unqualified_Decoded;
kono
parents:
diff changeset
621
kono
parents:
diff changeset
622 --------------
kono
parents:
diff changeset
623 -- Finalize --
kono
parents:
diff changeset
624 --------------
kono
parents:
diff changeset
625
kono
parents:
diff changeset
626 procedure Finalize is
kono
parents:
diff changeset
627 F : array (Int range 0 .. 50) of Int;
kono
parents:
diff changeset
628 -- N'th entry is the number of chains of length N, except last entry,
kono
parents:
diff changeset
629 -- which is the number of chains of length F'Last or more.
kono
parents:
diff changeset
630
kono
parents:
diff changeset
631 Max_Chain_Length : Nat := 0;
kono
parents:
diff changeset
632 -- Maximum length of all chains
kono
parents:
diff changeset
633
kono
parents:
diff changeset
634 Probes : Nat := 0;
kono
parents:
diff changeset
635 -- Used to compute average number of probes
kono
parents:
diff changeset
636
kono
parents:
diff changeset
637 Nsyms : Nat := 0;
kono
parents:
diff changeset
638 -- Number of symbols in table
kono
parents:
diff changeset
639
kono
parents:
diff changeset
640 Verbosity : constant Int range 1 .. 3 := 1;
kono
parents:
diff changeset
641 pragma Warnings (Off, Verbosity);
kono
parents:
diff changeset
642 -- This constant indicates the level of verbosity in the output from
kono
parents:
diff changeset
643 -- this procedure. Currently this can only be changed by editing the
kono
parents:
diff changeset
644 -- declaration above and recompiling. That's good enough in practice,
kono
parents:
diff changeset
645 -- since we very rarely need to use this debug option. Settings are:
kono
parents:
diff changeset
646 --
kono
parents:
diff changeset
647 -- 1 => print basic summary information
kono
parents:
diff changeset
648 -- 2 => in addition print number of entries per hash chain
kono
parents:
diff changeset
649 -- 3 => in addition print content of entries
kono
parents:
diff changeset
650
kono
parents:
diff changeset
651 Zero : constant Int := Character'Pos ('0');
kono
parents:
diff changeset
652
kono
parents:
diff changeset
653 begin
kono
parents:
diff changeset
654 if not Debug_Flag_H then
kono
parents:
diff changeset
655 return;
kono
parents:
diff changeset
656 end if;
kono
parents:
diff changeset
657
kono
parents:
diff changeset
658 for J in F'Range loop
kono
parents:
diff changeset
659 F (J) := 0;
kono
parents:
diff changeset
660 end loop;
kono
parents:
diff changeset
661
kono
parents:
diff changeset
662 for J in Hash_Index_Type loop
kono
parents:
diff changeset
663 if Hash_Table (J) = No_Name then
kono
parents:
diff changeset
664 F (0) := F (0) + 1;
kono
parents:
diff changeset
665
kono
parents:
diff changeset
666 else
kono
parents:
diff changeset
667 declare
kono
parents:
diff changeset
668 C : Nat;
kono
parents:
diff changeset
669 N : Name_Id;
kono
parents:
diff changeset
670 S : Int;
kono
parents:
diff changeset
671
kono
parents:
diff changeset
672 begin
kono
parents:
diff changeset
673 C := 0;
kono
parents:
diff changeset
674 N := Hash_Table (J);
kono
parents:
diff changeset
675
kono
parents:
diff changeset
676 while N /= No_Name loop
kono
parents:
diff changeset
677 N := Name_Entries.Table (N).Hash_Link;
kono
parents:
diff changeset
678 C := C + 1;
kono
parents:
diff changeset
679 end loop;
kono
parents:
diff changeset
680
kono
parents:
diff changeset
681 Nsyms := Nsyms + 1;
kono
parents:
diff changeset
682 Probes := Probes + (1 + C) * 100;
kono
parents:
diff changeset
683
kono
parents:
diff changeset
684 if C > Max_Chain_Length then
kono
parents:
diff changeset
685 Max_Chain_Length := C;
kono
parents:
diff changeset
686 end if;
kono
parents:
diff changeset
687
kono
parents:
diff changeset
688 if Verbosity >= 2 then
kono
parents:
diff changeset
689 Write_Str ("Hash_Table (");
kono
parents:
diff changeset
690 Write_Int (J);
kono
parents:
diff changeset
691 Write_Str (") has ");
kono
parents:
diff changeset
692 Write_Int (C);
kono
parents:
diff changeset
693 Write_Str (" entries");
kono
parents:
diff changeset
694 Write_Eol;
kono
parents:
diff changeset
695 end if;
kono
parents:
diff changeset
696
kono
parents:
diff changeset
697 if C < F'Last then
kono
parents:
diff changeset
698 F (C) := F (C) + 1;
kono
parents:
diff changeset
699 else
kono
parents:
diff changeset
700 F (F'Last) := F (F'Last) + 1;
kono
parents:
diff changeset
701 end if;
kono
parents:
diff changeset
702
kono
parents:
diff changeset
703 if Verbosity >= 3 then
kono
parents:
diff changeset
704 N := Hash_Table (J);
kono
parents:
diff changeset
705 while N /= No_Name loop
kono
parents:
diff changeset
706 S := Name_Entries.Table (N).Name_Chars_Index;
kono
parents:
diff changeset
707
kono
parents:
diff changeset
708 Write_Str (" ");
kono
parents:
diff changeset
709
kono
parents:
diff changeset
710 for J in 1 .. Name_Entries.Table (N).Name_Len loop
kono
parents:
diff changeset
711 Write_Char (Name_Chars.Table (S + Int (J)));
kono
parents:
diff changeset
712 end loop;
kono
parents:
diff changeset
713
kono
parents:
diff changeset
714 Write_Eol;
kono
parents:
diff changeset
715
kono
parents:
diff changeset
716 N := Name_Entries.Table (N).Hash_Link;
kono
parents:
diff changeset
717 end loop;
kono
parents:
diff changeset
718 end if;
kono
parents:
diff changeset
719 end;
kono
parents:
diff changeset
720 end if;
kono
parents:
diff changeset
721 end loop;
kono
parents:
diff changeset
722
kono
parents:
diff changeset
723 Write_Eol;
kono
parents:
diff changeset
724
kono
parents:
diff changeset
725 for J in F'Range loop
kono
parents:
diff changeset
726 if F (J) /= 0 then
kono
parents:
diff changeset
727 Write_Str ("Number of hash chains of length ");
kono
parents:
diff changeset
728
kono
parents:
diff changeset
729 if J < 10 then
kono
parents:
diff changeset
730 Write_Char (' ');
kono
parents:
diff changeset
731 end if;
kono
parents:
diff changeset
732
kono
parents:
diff changeset
733 Write_Int (J);
kono
parents:
diff changeset
734
kono
parents:
diff changeset
735 if J = F'Last then
kono
parents:
diff changeset
736 Write_Str (" or greater");
kono
parents:
diff changeset
737 end if;
kono
parents:
diff changeset
738
kono
parents:
diff changeset
739 Write_Str (" = ");
kono
parents:
diff changeset
740 Write_Int (F (J));
kono
parents:
diff changeset
741 Write_Eol;
kono
parents:
diff changeset
742 end if;
kono
parents:
diff changeset
743 end loop;
kono
parents:
diff changeset
744
kono
parents:
diff changeset
745 -- Print out average number of probes, in the case where Name_Find is
kono
parents:
diff changeset
746 -- called for a string that is already in the table.
kono
parents:
diff changeset
747
kono
parents:
diff changeset
748 Write_Eol;
kono
parents:
diff changeset
749 Write_Str ("Average number of probes for lookup = ");
kono
parents:
diff changeset
750 Probes := Probes / Nsyms;
kono
parents:
diff changeset
751 Write_Int (Probes / 200);
kono
parents:
diff changeset
752 Write_Char ('.');
kono
parents:
diff changeset
753 Probes := (Probes mod 200) / 2;
kono
parents:
diff changeset
754 Write_Char (Character'Val (Zero + Probes / 10));
kono
parents:
diff changeset
755 Write_Char (Character'Val (Zero + Probes mod 10));
kono
parents:
diff changeset
756 Write_Eol;
kono
parents:
diff changeset
757
kono
parents:
diff changeset
758 Write_Str ("Max_Chain_Length = ");
kono
parents:
diff changeset
759 Write_Int (Max_Chain_Length);
kono
parents:
diff changeset
760 Write_Eol;
kono
parents:
diff changeset
761 Write_Str ("Name_Chars'Length = ");
kono
parents:
diff changeset
762 Write_Int (Name_Chars.Last - Name_Chars.First + 1);
kono
parents:
diff changeset
763 Write_Eol;
kono
parents:
diff changeset
764 Write_Str ("Name_Entries'Length = ");
kono
parents:
diff changeset
765 Write_Int (Int (Name_Entries.Last - Name_Entries.First + 1));
kono
parents:
diff changeset
766 Write_Eol;
kono
parents:
diff changeset
767 Write_Str ("Nsyms = ");
kono
parents:
diff changeset
768 Write_Int (Nsyms);
kono
parents:
diff changeset
769 Write_Eol;
kono
parents:
diff changeset
770 end Finalize;
kono
parents:
diff changeset
771
kono
parents:
diff changeset
772 -----------------------------
kono
parents:
diff changeset
773 -- Get_Decoded_Name_String --
kono
parents:
diff changeset
774 -----------------------------
kono
parents:
diff changeset
775
kono
parents:
diff changeset
776 procedure Get_Decoded_Name_String (Id : Name_Id) is
kono
parents:
diff changeset
777 begin
kono
parents:
diff changeset
778 Global_Name_Buffer.Length := 0;
kono
parents:
diff changeset
779 Append_Decoded (Global_Name_Buffer, Id);
kono
parents:
diff changeset
780 end Get_Decoded_Name_String;
kono
parents:
diff changeset
781
kono
parents:
diff changeset
782 -------------------------------------------
kono
parents:
diff changeset
783 -- Get_Decoded_Name_String_With_Brackets --
kono
parents:
diff changeset
784 -------------------------------------------
kono
parents:
diff changeset
785
kono
parents:
diff changeset
786 procedure Get_Decoded_Name_String_With_Brackets (Id : Name_Id) is
kono
parents:
diff changeset
787 begin
kono
parents:
diff changeset
788 Global_Name_Buffer.Length := 0;
kono
parents:
diff changeset
789 Append_Decoded_With_Brackets (Global_Name_Buffer, Id);
kono
parents:
diff changeset
790 end Get_Decoded_Name_String_With_Brackets;
kono
parents:
diff changeset
791
kono
parents:
diff changeset
792 ------------------------
kono
parents:
diff changeset
793 -- Get_Last_Two_Chars --
kono
parents:
diff changeset
794 ------------------------
kono
parents:
diff changeset
795
kono
parents:
diff changeset
796 procedure Get_Last_Two_Chars
kono
parents:
diff changeset
797 (N : Name_Id;
kono
parents:
diff changeset
798 C1 : out Character;
kono
parents:
diff changeset
799 C2 : out Character)
kono
parents:
diff changeset
800 is
kono
parents:
diff changeset
801 NE : Name_Entry renames Name_Entries.Table (N);
kono
parents:
diff changeset
802 NEL : constant Int := Int (NE.Name_Len);
kono
parents:
diff changeset
803
kono
parents:
diff changeset
804 begin
kono
parents:
diff changeset
805 if NEL >= 2 then
kono
parents:
diff changeset
806 C1 := Name_Chars.Table (NE.Name_Chars_Index + NEL - 1);
kono
parents:
diff changeset
807 C2 := Name_Chars.Table (NE.Name_Chars_Index + NEL - 0);
kono
parents:
diff changeset
808 else
kono
parents:
diff changeset
809 C1 := ASCII.NUL;
kono
parents:
diff changeset
810 C2 := ASCII.NUL;
kono
parents:
diff changeset
811 end if;
kono
parents:
diff changeset
812 end Get_Last_Two_Chars;
kono
parents:
diff changeset
813
kono
parents:
diff changeset
814 ---------------------
kono
parents:
diff changeset
815 -- Get_Name_String --
kono
parents:
diff changeset
816 ---------------------
kono
parents:
diff changeset
817
kono
parents:
diff changeset
818 procedure Get_Name_String (Id : Name_Id) is
kono
parents:
diff changeset
819 begin
kono
parents:
diff changeset
820 Global_Name_Buffer.Length := 0;
kono
parents:
diff changeset
821 Append (Global_Name_Buffer, Id);
kono
parents:
diff changeset
822 end Get_Name_String;
kono
parents:
diff changeset
823
kono
parents:
diff changeset
824 function Get_Name_String (Id : Name_Id) return String is
kono
parents:
diff changeset
825 Buf : Bounded_String (Max_Length => Natural (Length_Of_Name (Id)));
kono
parents:
diff changeset
826 begin
kono
parents:
diff changeset
827 Append (Buf, Id);
kono
parents:
diff changeset
828 return +Buf;
kono
parents:
diff changeset
829 end Get_Name_String;
kono
parents:
diff changeset
830
kono
parents:
diff changeset
831 --------------------------------
kono
parents:
diff changeset
832 -- Get_Name_String_And_Append --
kono
parents:
diff changeset
833 --------------------------------
kono
parents:
diff changeset
834
kono
parents:
diff changeset
835 procedure Get_Name_String_And_Append (Id : Name_Id) is
kono
parents:
diff changeset
836 begin
kono
parents:
diff changeset
837 Append (Global_Name_Buffer, Id);
kono
parents:
diff changeset
838 end Get_Name_String_And_Append;
kono
parents:
diff changeset
839
kono
parents:
diff changeset
840 -----------------------------
kono
parents:
diff changeset
841 -- Get_Name_Table_Boolean1 --
kono
parents:
diff changeset
842 -----------------------------
kono
parents:
diff changeset
843
kono
parents:
diff changeset
844 function Get_Name_Table_Boolean1 (Id : Name_Id) return Boolean is
kono
parents:
diff changeset
845 begin
kono
parents:
diff changeset
846 pragma Assert (Id in Name_Entries.First .. Name_Entries.Last);
kono
parents:
diff changeset
847 return Name_Entries.Table (Id).Boolean1_Info;
kono
parents:
diff changeset
848 end Get_Name_Table_Boolean1;
kono
parents:
diff changeset
849
kono
parents:
diff changeset
850 -----------------------------
kono
parents:
diff changeset
851 -- Get_Name_Table_Boolean2 --
kono
parents:
diff changeset
852 -----------------------------
kono
parents:
diff changeset
853
kono
parents:
diff changeset
854 function Get_Name_Table_Boolean2 (Id : Name_Id) return Boolean is
kono
parents:
diff changeset
855 begin
kono
parents:
diff changeset
856 pragma Assert (Id in Name_Entries.First .. Name_Entries.Last);
kono
parents:
diff changeset
857 return Name_Entries.Table (Id).Boolean2_Info;
kono
parents:
diff changeset
858 end Get_Name_Table_Boolean2;
kono
parents:
diff changeset
859
kono
parents:
diff changeset
860 -----------------------------
kono
parents:
diff changeset
861 -- Get_Name_Table_Boolean3 --
kono
parents:
diff changeset
862 -----------------------------
kono
parents:
diff changeset
863
kono
parents:
diff changeset
864 function Get_Name_Table_Boolean3 (Id : Name_Id) return Boolean is
kono
parents:
diff changeset
865 begin
kono
parents:
diff changeset
866 pragma Assert (Id in Name_Entries.First .. Name_Entries.Last);
kono
parents:
diff changeset
867 return Name_Entries.Table (Id).Boolean3_Info;
kono
parents:
diff changeset
868 end Get_Name_Table_Boolean3;
kono
parents:
diff changeset
869
kono
parents:
diff changeset
870 -------------------------
kono
parents:
diff changeset
871 -- Get_Name_Table_Byte --
kono
parents:
diff changeset
872 -------------------------
kono
parents:
diff changeset
873
kono
parents:
diff changeset
874 function Get_Name_Table_Byte (Id : Name_Id) return Byte is
kono
parents:
diff changeset
875 begin
kono
parents:
diff changeset
876 pragma Assert (Id in Name_Entries.First .. Name_Entries.Last);
kono
parents:
diff changeset
877 return Name_Entries.Table (Id).Byte_Info;
kono
parents:
diff changeset
878 end Get_Name_Table_Byte;
kono
parents:
diff changeset
879
kono
parents:
diff changeset
880 -------------------------
kono
parents:
diff changeset
881 -- Get_Name_Table_Int --
kono
parents:
diff changeset
882 -------------------------
kono
parents:
diff changeset
883
kono
parents:
diff changeset
884 function Get_Name_Table_Int (Id : Name_Id) return Int is
kono
parents:
diff changeset
885 begin
kono
parents:
diff changeset
886 pragma Assert (Id in Name_Entries.First .. Name_Entries.Last);
kono
parents:
diff changeset
887 return Name_Entries.Table (Id).Int_Info;
kono
parents:
diff changeset
888 end Get_Name_Table_Int;
kono
parents:
diff changeset
889
kono
parents:
diff changeset
890 -----------------------------------------
kono
parents:
diff changeset
891 -- Get_Unqualified_Decoded_Name_String --
kono
parents:
diff changeset
892 -----------------------------------------
kono
parents:
diff changeset
893
kono
parents:
diff changeset
894 procedure Get_Unqualified_Decoded_Name_String (Id : Name_Id) is
kono
parents:
diff changeset
895 begin
kono
parents:
diff changeset
896 Global_Name_Buffer.Length := 0;
kono
parents:
diff changeset
897 Append_Unqualified_Decoded (Global_Name_Buffer, Id);
kono
parents:
diff changeset
898 end Get_Unqualified_Decoded_Name_String;
kono
parents:
diff changeset
899
kono
parents:
diff changeset
900 ---------------------------------
kono
parents:
diff changeset
901 -- Get_Unqualified_Name_String --
kono
parents:
diff changeset
902 ---------------------------------
kono
parents:
diff changeset
903
kono
parents:
diff changeset
904 procedure Get_Unqualified_Name_String (Id : Name_Id) is
kono
parents:
diff changeset
905 begin
kono
parents:
diff changeset
906 Global_Name_Buffer.Length := 0;
kono
parents:
diff changeset
907 Append_Unqualified (Global_Name_Buffer, Id);
kono
parents:
diff changeset
908 end Get_Unqualified_Name_String;
kono
parents:
diff changeset
909
kono
parents:
diff changeset
910 ----------
kono
parents:
diff changeset
911 -- Hash --
kono
parents:
diff changeset
912 ----------
kono
parents:
diff changeset
913
kono
parents:
diff changeset
914 function Hash (Buf : Bounded_String) return Hash_Index_Type is
kono
parents:
diff changeset
915
kono
parents:
diff changeset
916 -- This hash function looks at every character, in order to make it
kono
parents:
diff changeset
917 -- likely that similar strings get different hash values. The rotate by
kono
parents:
diff changeset
918 -- 7 bits has been determined empirically to be good, and it doesn't
kono
parents:
diff changeset
919 -- lose bits like a shift would. The final conversion can't overflow,
kono
parents:
diff changeset
920 -- because the table is 2**16 in size. This function probably needs to
kono
parents:
diff changeset
921 -- be changed if the hash table size is changed.
kono
parents:
diff changeset
922
kono
parents:
diff changeset
923 -- Note that we could get some speed improvement by aligning the string
kono
parents:
diff changeset
924 -- to 32 or 64 bits, and doing word-wise xor's. We could also implement
kono
parents:
diff changeset
925 -- a growable table. It doesn't seem worth the trouble to do those
kono
parents:
diff changeset
926 -- things, for now.
kono
parents:
diff changeset
927
kono
parents:
diff changeset
928 Result : Unsigned_16 := 0;
kono
parents:
diff changeset
929
kono
parents:
diff changeset
930 begin
kono
parents:
diff changeset
931 for J in 1 .. Buf.Length loop
kono
parents:
diff changeset
932 Result := Rotate_Left (Result, 7) xor Character'Pos (Buf.Chars (J));
kono
parents:
diff changeset
933 end loop;
kono
parents:
diff changeset
934
kono
parents:
diff changeset
935 return Hash_Index_Type (Result);
kono
parents:
diff changeset
936 end Hash;
kono
parents:
diff changeset
937
kono
parents:
diff changeset
938 ----------------
kono
parents:
diff changeset
939 -- Initialize --
kono
parents:
diff changeset
940 ----------------
kono
parents:
diff changeset
941
kono
parents:
diff changeset
942 procedure Initialize is
kono
parents:
diff changeset
943 begin
kono
parents:
diff changeset
944 null;
kono
parents:
diff changeset
945 end Initialize;
kono
parents:
diff changeset
946
kono
parents:
diff changeset
947 ----------------
kono
parents:
diff changeset
948 -- Insert_Str --
kono
parents:
diff changeset
949 ----------------
kono
parents:
diff changeset
950
kono
parents:
diff changeset
951 procedure Insert_Str
kono
parents:
diff changeset
952 (Buf : in out Bounded_String;
kono
parents:
diff changeset
953 S : String;
kono
parents:
diff changeset
954 Index : Positive)
kono
parents:
diff changeset
955 is
kono
parents:
diff changeset
956 SL : constant Natural := S'Length;
kono
parents:
diff changeset
957
kono
parents:
diff changeset
958 begin
kono
parents:
diff changeset
959 Buf.Chars (Index + SL .. Buf.Length + SL) :=
kono
parents:
diff changeset
960 Buf.Chars (Index .. Buf.Length);
kono
parents:
diff changeset
961 Buf.Chars (Index .. Index + SL - 1) := S;
kono
parents:
diff changeset
962 Buf.Length := Buf.Length + SL;
kono
parents:
diff changeset
963 end Insert_Str;
kono
parents:
diff changeset
964
kono
parents:
diff changeset
965 -------------------------------
kono
parents:
diff changeset
966 -- Insert_Str_In_Name_Buffer --
kono
parents:
diff changeset
967 -------------------------------
kono
parents:
diff changeset
968
kono
parents:
diff changeset
969 procedure Insert_Str_In_Name_Buffer (S : String; Index : Positive) is
kono
parents:
diff changeset
970 begin
kono
parents:
diff changeset
971 Insert_Str (Global_Name_Buffer, S, Index);
kono
parents:
diff changeset
972 end Insert_Str_In_Name_Buffer;
kono
parents:
diff changeset
973
kono
parents:
diff changeset
974 ----------------------
kono
parents:
diff changeset
975 -- Is_Internal_Name --
kono
parents:
diff changeset
976 ----------------------
kono
parents:
diff changeset
977
kono
parents:
diff changeset
978 function Is_Internal_Name (Buf : Bounded_String) return Boolean is
kono
parents:
diff changeset
979 J : Natural;
kono
parents:
diff changeset
980
kono
parents:
diff changeset
981 begin
kono
parents:
diff changeset
982 -- Any name starting or ending with underscore is internal
kono
parents:
diff changeset
983
kono
parents:
diff changeset
984 if Buf.Chars (1) = '_'
kono
parents:
diff changeset
985 or else Buf.Chars (Buf.Length) = '_'
kono
parents:
diff changeset
986 then
kono
parents:
diff changeset
987 return True;
kono
parents:
diff changeset
988
kono
parents:
diff changeset
989 -- Allow quoted character
kono
parents:
diff changeset
990
kono
parents:
diff changeset
991 elsif Buf.Chars (1) = ''' then
kono
parents:
diff changeset
992 return False;
kono
parents:
diff changeset
993
kono
parents:
diff changeset
994 -- All other cases, scan name
kono
parents:
diff changeset
995
kono
parents:
diff changeset
996 else
kono
parents:
diff changeset
997 -- Test backwards, because we only want to test the last entity
kono
parents:
diff changeset
998 -- name if the name we have is qualified with other entities.
kono
parents:
diff changeset
999
kono
parents:
diff changeset
1000 J := Buf.Length;
kono
parents:
diff changeset
1001 while J /= 0 loop
kono
parents:
diff changeset
1002
kono
parents:
diff changeset
1003 -- Skip stuff between brackets (A-F OK there)
kono
parents:
diff changeset
1004
kono
parents:
diff changeset
1005 if Buf.Chars (J) = ']' then
kono
parents:
diff changeset
1006 loop
kono
parents:
diff changeset
1007 J := J - 1;
kono
parents:
diff changeset
1008 exit when J = 1 or else Buf.Chars (J) = '[';
kono
parents:
diff changeset
1009 end loop;
kono
parents:
diff changeset
1010
kono
parents:
diff changeset
1011 -- Test for internal letter
kono
parents:
diff changeset
1012
kono
parents:
diff changeset
1013 elsif Is_OK_Internal_Letter (Buf.Chars (J)) then
kono
parents:
diff changeset
1014 return True;
kono
parents:
diff changeset
1015
kono
parents:
diff changeset
1016 -- Quit if we come to terminating double underscore (note that
kono
parents:
diff changeset
1017 -- if the current character is an underscore, we know that
kono
parents:
diff changeset
1018 -- there is a previous character present, since we already
kono
parents:
diff changeset
1019 -- filtered out the case of Buf.Chars (1) = '_' above.
kono
parents:
diff changeset
1020
kono
parents:
diff changeset
1021 elsif Buf.Chars (J) = '_'
kono
parents:
diff changeset
1022 and then Buf.Chars (J - 1) = '_'
kono
parents:
diff changeset
1023 and then Buf.Chars (J - 2) /= '_'
kono
parents:
diff changeset
1024 then
kono
parents:
diff changeset
1025 return False;
kono
parents:
diff changeset
1026 end if;
kono
parents:
diff changeset
1027
kono
parents:
diff changeset
1028 J := J - 1;
kono
parents:
diff changeset
1029 end loop;
kono
parents:
diff changeset
1030 end if;
kono
parents:
diff changeset
1031
kono
parents:
diff changeset
1032 return False;
kono
parents:
diff changeset
1033 end Is_Internal_Name;
kono
parents:
diff changeset
1034
kono
parents:
diff changeset
1035 function Is_Internal_Name (Id : Name_Id) return Boolean is
kono
parents:
diff changeset
1036 Buf : Bounded_String (Max_Length => Natural (Length_Of_Name (Id)));
kono
parents:
diff changeset
1037 begin
kono
parents:
diff changeset
1038 if Id in Error_Name_Or_No_Name then
kono
parents:
diff changeset
1039 return False;
kono
parents:
diff changeset
1040 else
kono
parents:
diff changeset
1041 Append (Buf, Id);
kono
parents:
diff changeset
1042 return Is_Internal_Name (Buf);
kono
parents:
diff changeset
1043 end if;
kono
parents:
diff changeset
1044 end Is_Internal_Name;
kono
parents:
diff changeset
1045
kono
parents:
diff changeset
1046 function Is_Internal_Name return Boolean is
kono
parents:
diff changeset
1047 begin
kono
parents:
diff changeset
1048 return Is_Internal_Name (Global_Name_Buffer);
kono
parents:
diff changeset
1049 end Is_Internal_Name;
kono
parents:
diff changeset
1050
kono
parents:
diff changeset
1051 ---------------------------
kono
parents:
diff changeset
1052 -- Is_OK_Internal_Letter --
kono
parents:
diff changeset
1053 ---------------------------
kono
parents:
diff changeset
1054
kono
parents:
diff changeset
1055 function Is_OK_Internal_Letter (C : Character) return Boolean is
kono
parents:
diff changeset
1056 begin
kono
parents:
diff changeset
1057 return C in 'A' .. 'Z'
kono
parents:
diff changeset
1058 and then C /= 'O'
kono
parents:
diff changeset
1059 and then C /= 'Q'
kono
parents:
diff changeset
1060 and then C /= 'U'
kono
parents:
diff changeset
1061 and then C /= 'W'
kono
parents:
diff changeset
1062 and then C /= 'X';
kono
parents:
diff changeset
1063 end Is_OK_Internal_Letter;
kono
parents:
diff changeset
1064
kono
parents:
diff changeset
1065 ----------------------
kono
parents:
diff changeset
1066 -- Is_Operator_Name --
kono
parents:
diff changeset
1067 ----------------------
kono
parents:
diff changeset
1068
kono
parents:
diff changeset
1069 function Is_Operator_Name (Id : Name_Id) return Boolean is
kono
parents:
diff changeset
1070 S : Int;
kono
parents:
diff changeset
1071 begin
kono
parents:
diff changeset
1072 pragma Assert (Id in Name_Entries.First .. Name_Entries.Last);
kono
parents:
diff changeset
1073 S := Name_Entries.Table (Id).Name_Chars_Index;
kono
parents:
diff changeset
1074 return Name_Chars.Table (S + 1) = 'O';
kono
parents:
diff changeset
1075 end Is_Operator_Name;
kono
parents:
diff changeset
1076
kono
parents:
diff changeset
1077 -------------------
kono
parents:
diff changeset
1078 -- Is_Valid_Name --
kono
parents:
diff changeset
1079 -------------------
kono
parents:
diff changeset
1080
kono
parents:
diff changeset
1081 function Is_Valid_Name (Id : Name_Id) return Boolean is
kono
parents:
diff changeset
1082 begin
kono
parents:
diff changeset
1083 return Id in Name_Entries.First .. Name_Entries.Last;
kono
parents:
diff changeset
1084 end Is_Valid_Name;
kono
parents:
diff changeset
1085
kono
parents:
diff changeset
1086 --------------------
kono
parents:
diff changeset
1087 -- Length_Of_Name --
kono
parents:
diff changeset
1088 --------------------
kono
parents:
diff changeset
1089
kono
parents:
diff changeset
1090 function Length_Of_Name (Id : Name_Id) return Nat is
kono
parents:
diff changeset
1091 begin
kono
parents:
diff changeset
1092 return Int (Name_Entries.Table (Id).Name_Len);
kono
parents:
diff changeset
1093 end Length_Of_Name;
kono
parents:
diff changeset
1094
kono
parents:
diff changeset
1095 ----------
kono
parents:
diff changeset
1096 -- Lock --
kono
parents:
diff changeset
1097 ----------
kono
parents:
diff changeset
1098
kono
parents:
diff changeset
1099 procedure Lock is
kono
parents:
diff changeset
1100 begin
kono
parents:
diff changeset
1101 Name_Chars.Set_Last (Name_Chars.Last + Name_Chars_Reserve);
kono
parents:
diff changeset
1102 Name_Entries.Set_Last (Name_Entries.Last + Name_Entries_Reserve);
kono
parents:
diff changeset
1103 Name_Chars.Release;
kono
parents:
diff changeset
1104 Name_Chars.Locked := True;
kono
parents:
diff changeset
1105 Name_Entries.Release;
kono
parents:
diff changeset
1106 Name_Entries.Locked := True;
kono
parents:
diff changeset
1107 end Lock;
kono
parents:
diff changeset
1108
kono
parents:
diff changeset
1109 ----------------
kono
parents:
diff changeset
1110 -- Name_Enter --
kono
parents:
diff changeset
1111 ----------------
kono
parents:
diff changeset
1112
kono
parents:
diff changeset
1113 function Name_Enter
kono
parents:
diff changeset
1114 (Buf : Bounded_String := Global_Name_Buffer) return Name_Id
kono
parents:
diff changeset
1115 is
kono
parents:
diff changeset
1116 begin
kono
parents:
diff changeset
1117 Name_Entries.Append
kono
parents:
diff changeset
1118 ((Name_Chars_Index => Name_Chars.Last,
kono
parents:
diff changeset
1119 Name_Len => Short (Buf.Length),
kono
parents:
diff changeset
1120 Byte_Info => 0,
kono
parents:
diff changeset
1121 Int_Info => 0,
kono
parents:
diff changeset
1122 Boolean1_Info => False,
kono
parents:
diff changeset
1123 Boolean2_Info => False,
kono
parents:
diff changeset
1124 Boolean3_Info => False,
kono
parents:
diff changeset
1125 Name_Has_No_Encodings => False,
kono
parents:
diff changeset
1126 Hash_Link => No_Name));
kono
parents:
diff changeset
1127
kono
parents:
diff changeset
1128 -- Set corresponding string entry in the Name_Chars table
kono
parents:
diff changeset
1129
kono
parents:
diff changeset
1130 for J in 1 .. Buf.Length loop
kono
parents:
diff changeset
1131 Name_Chars.Append (Buf.Chars (J));
kono
parents:
diff changeset
1132 end loop;
kono
parents:
diff changeset
1133
kono
parents:
diff changeset
1134 Name_Chars.Append (ASCII.NUL);
kono
parents:
diff changeset
1135
kono
parents:
diff changeset
1136 return Name_Entries.Last;
kono
parents:
diff changeset
1137 end Name_Enter;
kono
parents:
diff changeset
1138
kono
parents:
diff changeset
1139 function Name_Enter (S : String) return Name_Id is
kono
parents:
diff changeset
1140 Buf : Bounded_String (Max_Length => S'Length);
kono
parents:
diff changeset
1141 begin
kono
parents:
diff changeset
1142 Append (Buf, S);
kono
parents:
diff changeset
1143 return Name_Enter (Buf);
kono
parents:
diff changeset
1144 end Name_Enter;
kono
parents:
diff changeset
1145
kono
parents:
diff changeset
1146 ------------------------
kono
parents:
diff changeset
1147 -- Name_Entries_Count --
kono
parents:
diff changeset
1148 ------------------------
kono
parents:
diff changeset
1149
kono
parents:
diff changeset
1150 function Name_Entries_Count return Nat is
kono
parents:
diff changeset
1151 begin
kono
parents:
diff changeset
1152 return Int (Name_Entries.Last - Name_Entries.First + 1);
kono
parents:
diff changeset
1153 end Name_Entries_Count;
kono
parents:
diff changeset
1154
kono
parents:
diff changeset
1155 ---------------
kono
parents:
diff changeset
1156 -- Name_Find --
kono
parents:
diff changeset
1157 ---------------
kono
parents:
diff changeset
1158
kono
parents:
diff changeset
1159 function Name_Find
kono
parents:
diff changeset
1160 (Buf : Bounded_String := Global_Name_Buffer) return Name_Id
kono
parents:
diff changeset
1161 is
kono
parents:
diff changeset
1162 New_Id : Name_Id;
kono
parents:
diff changeset
1163 -- Id of entry in hash search, and value to be returned
kono
parents:
diff changeset
1164
kono
parents:
diff changeset
1165 S : Int;
kono
parents:
diff changeset
1166 -- Pointer into string table
kono
parents:
diff changeset
1167
kono
parents:
diff changeset
1168 Hash_Index : Hash_Index_Type;
kono
parents:
diff changeset
1169 -- Computed hash index
kono
parents:
diff changeset
1170
kono
parents:
diff changeset
1171 begin
kono
parents:
diff changeset
1172 -- Quick handling for one character names
kono
parents:
diff changeset
1173
kono
parents:
diff changeset
1174 if Buf.Length = 1 then
kono
parents:
diff changeset
1175 return Name_Id (First_Name_Id + Character'Pos (Buf.Chars (1)));
kono
parents:
diff changeset
1176
kono
parents:
diff changeset
1177 -- Otherwise search hash table for existing matching entry
kono
parents:
diff changeset
1178
kono
parents:
diff changeset
1179 else
kono
parents:
diff changeset
1180 Hash_Index := Namet.Hash (Buf);
kono
parents:
diff changeset
1181 New_Id := Hash_Table (Hash_Index);
kono
parents:
diff changeset
1182
kono
parents:
diff changeset
1183 if New_Id = No_Name then
kono
parents:
diff changeset
1184 Hash_Table (Hash_Index) := Name_Entries.Last + 1;
kono
parents:
diff changeset
1185
kono
parents:
diff changeset
1186 else
kono
parents:
diff changeset
1187 Search : loop
kono
parents:
diff changeset
1188 if Buf.Length /=
kono
parents:
diff changeset
1189 Integer (Name_Entries.Table (New_Id).Name_Len)
kono
parents:
diff changeset
1190 then
kono
parents:
diff changeset
1191 goto No_Match;
kono
parents:
diff changeset
1192 end if;
kono
parents:
diff changeset
1193
kono
parents:
diff changeset
1194 S := Name_Entries.Table (New_Id).Name_Chars_Index;
kono
parents:
diff changeset
1195
kono
parents:
diff changeset
1196 for J in 1 .. Buf.Length loop
kono
parents:
diff changeset
1197 if Name_Chars.Table (S + Int (J)) /= Buf.Chars (J) then
kono
parents:
diff changeset
1198 goto No_Match;
kono
parents:
diff changeset
1199 end if;
kono
parents:
diff changeset
1200 end loop;
kono
parents:
diff changeset
1201
kono
parents:
diff changeset
1202 return New_Id;
kono
parents:
diff changeset
1203
kono
parents:
diff changeset
1204 -- Current entry in hash chain does not match
kono
parents:
diff changeset
1205
kono
parents:
diff changeset
1206 <<No_Match>>
kono
parents:
diff changeset
1207 if Name_Entries.Table (New_Id).Hash_Link /= No_Name then
kono
parents:
diff changeset
1208 New_Id := Name_Entries.Table (New_Id).Hash_Link;
kono
parents:
diff changeset
1209 else
kono
parents:
diff changeset
1210 Name_Entries.Table (New_Id).Hash_Link :=
kono
parents:
diff changeset
1211 Name_Entries.Last + 1;
kono
parents:
diff changeset
1212 exit Search;
kono
parents:
diff changeset
1213 end if;
kono
parents:
diff changeset
1214 end loop Search;
kono
parents:
diff changeset
1215 end if;
kono
parents:
diff changeset
1216
kono
parents:
diff changeset
1217 -- We fall through here only if a matching entry was not found in the
kono
parents:
diff changeset
1218 -- hash table. We now create a new entry in the names table. The hash
kono
parents:
diff changeset
1219 -- link pointing to the new entry (Name_Entries.Last+1) has been set.
kono
parents:
diff changeset
1220
kono
parents:
diff changeset
1221 Name_Entries.Append
kono
parents:
diff changeset
1222 ((Name_Chars_Index => Name_Chars.Last,
kono
parents:
diff changeset
1223 Name_Len => Short (Buf.Length),
kono
parents:
diff changeset
1224 Hash_Link => No_Name,
kono
parents:
diff changeset
1225 Name_Has_No_Encodings => False,
kono
parents:
diff changeset
1226 Int_Info => 0,
kono
parents:
diff changeset
1227 Byte_Info => 0,
kono
parents:
diff changeset
1228 Boolean1_Info => False,
kono
parents:
diff changeset
1229 Boolean2_Info => False,
kono
parents:
diff changeset
1230 Boolean3_Info => False));
kono
parents:
diff changeset
1231
kono
parents:
diff changeset
1232 -- Set corresponding string entry in the Name_Chars table
kono
parents:
diff changeset
1233
kono
parents:
diff changeset
1234 for J in 1 .. Buf.Length loop
kono
parents:
diff changeset
1235 Name_Chars.Append (Buf.Chars (J));
kono
parents:
diff changeset
1236 end loop;
kono
parents:
diff changeset
1237
kono
parents:
diff changeset
1238 Name_Chars.Append (ASCII.NUL);
kono
parents:
diff changeset
1239
kono
parents:
diff changeset
1240 return Name_Entries.Last;
kono
parents:
diff changeset
1241 end if;
kono
parents:
diff changeset
1242 end Name_Find;
kono
parents:
diff changeset
1243
kono
parents:
diff changeset
1244 function Name_Find (S : String) return Name_Id is
kono
parents:
diff changeset
1245 Buf : Bounded_String (Max_Length => S'Length);
kono
parents:
diff changeset
1246 begin
kono
parents:
diff changeset
1247 Append (Buf, S);
kono
parents:
diff changeset
1248 return Name_Find (Buf);
kono
parents:
diff changeset
1249 end Name_Find;
kono
parents:
diff changeset
1250
kono
parents:
diff changeset
1251 -------------
kono
parents:
diff changeset
1252 -- Nam_In --
kono
parents:
diff changeset
1253 -------------
kono
parents:
diff changeset
1254
kono
parents:
diff changeset
1255 function Nam_In
kono
parents:
diff changeset
1256 (T : Name_Id;
kono
parents:
diff changeset
1257 V1 : Name_Id;
kono
parents:
diff changeset
1258 V2 : Name_Id) return Boolean
kono
parents:
diff changeset
1259 is
kono
parents:
diff changeset
1260 begin
kono
parents:
diff changeset
1261 return T = V1 or else
kono
parents:
diff changeset
1262 T = V2;
kono
parents:
diff changeset
1263 end Nam_In;
kono
parents:
diff changeset
1264
kono
parents:
diff changeset
1265 function Nam_In
kono
parents:
diff changeset
1266 (T : Name_Id;
kono
parents:
diff changeset
1267 V1 : Name_Id;
kono
parents:
diff changeset
1268 V2 : Name_Id;
kono
parents:
diff changeset
1269 V3 : Name_Id) return Boolean
kono
parents:
diff changeset
1270 is
kono
parents:
diff changeset
1271 begin
kono
parents:
diff changeset
1272 return T = V1 or else
kono
parents:
diff changeset
1273 T = V2 or else
kono
parents:
diff changeset
1274 T = V3;
kono
parents:
diff changeset
1275 end Nam_In;
kono
parents:
diff changeset
1276
kono
parents:
diff changeset
1277 function Nam_In
kono
parents:
diff changeset
1278 (T : Name_Id;
kono
parents:
diff changeset
1279 V1 : Name_Id;
kono
parents:
diff changeset
1280 V2 : Name_Id;
kono
parents:
diff changeset
1281 V3 : Name_Id;
kono
parents:
diff changeset
1282 V4 : Name_Id) return Boolean
kono
parents:
diff changeset
1283 is
kono
parents:
diff changeset
1284 begin
kono
parents:
diff changeset
1285 return T = V1 or else
kono
parents:
diff changeset
1286 T = V2 or else
kono
parents:
diff changeset
1287 T = V3 or else
kono
parents:
diff changeset
1288 T = V4;
kono
parents:
diff changeset
1289 end Nam_In;
kono
parents:
diff changeset
1290
kono
parents:
diff changeset
1291 function Nam_In
kono
parents:
diff changeset
1292 (T : Name_Id;
kono
parents:
diff changeset
1293 V1 : Name_Id;
kono
parents:
diff changeset
1294 V2 : Name_Id;
kono
parents:
diff changeset
1295 V3 : Name_Id;
kono
parents:
diff changeset
1296 V4 : Name_Id;
kono
parents:
diff changeset
1297 V5 : Name_Id) return Boolean
kono
parents:
diff changeset
1298 is
kono
parents:
diff changeset
1299 begin
kono
parents:
diff changeset
1300 return T = V1 or else
kono
parents:
diff changeset
1301 T = V2 or else
kono
parents:
diff changeset
1302 T = V3 or else
kono
parents:
diff changeset
1303 T = V4 or else
kono
parents:
diff changeset
1304 T = V5;
kono
parents:
diff changeset
1305 end Nam_In;
kono
parents:
diff changeset
1306
kono
parents:
diff changeset
1307 function Nam_In
kono
parents:
diff changeset
1308 (T : Name_Id;
kono
parents:
diff changeset
1309 V1 : Name_Id;
kono
parents:
diff changeset
1310 V2 : Name_Id;
kono
parents:
diff changeset
1311 V3 : Name_Id;
kono
parents:
diff changeset
1312 V4 : Name_Id;
kono
parents:
diff changeset
1313 V5 : Name_Id;
kono
parents:
diff changeset
1314 V6 : Name_Id) return Boolean
kono
parents:
diff changeset
1315 is
kono
parents:
diff changeset
1316 begin
kono
parents:
diff changeset
1317 return T = V1 or else
kono
parents:
diff changeset
1318 T = V2 or else
kono
parents:
diff changeset
1319 T = V3 or else
kono
parents:
diff changeset
1320 T = V4 or else
kono
parents:
diff changeset
1321 T = V5 or else
kono
parents:
diff changeset
1322 T = V6;
kono
parents:
diff changeset
1323 end Nam_In;
kono
parents:
diff changeset
1324
kono
parents:
diff changeset
1325 function Nam_In
kono
parents:
diff changeset
1326 (T : Name_Id;
kono
parents:
diff changeset
1327 V1 : Name_Id;
kono
parents:
diff changeset
1328 V2 : Name_Id;
kono
parents:
diff changeset
1329 V3 : Name_Id;
kono
parents:
diff changeset
1330 V4 : Name_Id;
kono
parents:
diff changeset
1331 V5 : Name_Id;
kono
parents:
diff changeset
1332 V6 : Name_Id;
kono
parents:
diff changeset
1333 V7 : Name_Id) return Boolean
kono
parents:
diff changeset
1334 is
kono
parents:
diff changeset
1335 begin
kono
parents:
diff changeset
1336 return T = V1 or else
kono
parents:
diff changeset
1337 T = V2 or else
kono
parents:
diff changeset
1338 T = V3 or else
kono
parents:
diff changeset
1339 T = V4 or else
kono
parents:
diff changeset
1340 T = V5 or else
kono
parents:
diff changeset
1341 T = V6 or else
kono
parents:
diff changeset
1342 T = V7;
kono
parents:
diff changeset
1343 end Nam_In;
kono
parents:
diff changeset
1344
kono
parents:
diff changeset
1345 function Nam_In
kono
parents:
diff changeset
1346 (T : Name_Id;
kono
parents:
diff changeset
1347 V1 : Name_Id;
kono
parents:
diff changeset
1348 V2 : Name_Id;
kono
parents:
diff changeset
1349 V3 : Name_Id;
kono
parents:
diff changeset
1350 V4 : Name_Id;
kono
parents:
diff changeset
1351 V5 : Name_Id;
kono
parents:
diff changeset
1352 V6 : Name_Id;
kono
parents:
diff changeset
1353 V7 : Name_Id;
kono
parents:
diff changeset
1354 V8 : Name_Id) return Boolean
kono
parents:
diff changeset
1355 is
kono
parents:
diff changeset
1356 begin
kono
parents:
diff changeset
1357 return T = V1 or else
kono
parents:
diff changeset
1358 T = V2 or else
kono
parents:
diff changeset
1359 T = V3 or else
kono
parents:
diff changeset
1360 T = V4 or else
kono
parents:
diff changeset
1361 T = V5 or else
kono
parents:
diff changeset
1362 T = V6 or else
kono
parents:
diff changeset
1363 T = V7 or else
kono
parents:
diff changeset
1364 T = V8;
kono
parents:
diff changeset
1365 end Nam_In;
kono
parents:
diff changeset
1366
kono
parents:
diff changeset
1367 function Nam_In
kono
parents:
diff changeset
1368 (T : Name_Id;
kono
parents:
diff changeset
1369 V1 : Name_Id;
kono
parents:
diff changeset
1370 V2 : Name_Id;
kono
parents:
diff changeset
1371 V3 : Name_Id;
kono
parents:
diff changeset
1372 V4 : Name_Id;
kono
parents:
diff changeset
1373 V5 : Name_Id;
kono
parents:
diff changeset
1374 V6 : Name_Id;
kono
parents:
diff changeset
1375 V7 : Name_Id;
kono
parents:
diff changeset
1376 V8 : Name_Id;
kono
parents:
diff changeset
1377 V9 : Name_Id) return Boolean
kono
parents:
diff changeset
1378 is
kono
parents:
diff changeset
1379 begin
kono
parents:
diff changeset
1380 return T = V1 or else
kono
parents:
diff changeset
1381 T = V2 or else
kono
parents:
diff changeset
1382 T = V3 or else
kono
parents:
diff changeset
1383 T = V4 or else
kono
parents:
diff changeset
1384 T = V5 or else
kono
parents:
diff changeset
1385 T = V6 or else
kono
parents:
diff changeset
1386 T = V7 or else
kono
parents:
diff changeset
1387 T = V8 or else
kono
parents:
diff changeset
1388 T = V9;
kono
parents:
diff changeset
1389 end Nam_In;
kono
parents:
diff changeset
1390
kono
parents:
diff changeset
1391 function Nam_In
kono
parents:
diff changeset
1392 (T : Name_Id;
kono
parents:
diff changeset
1393 V1 : Name_Id;
kono
parents:
diff changeset
1394 V2 : Name_Id;
kono
parents:
diff changeset
1395 V3 : Name_Id;
kono
parents:
diff changeset
1396 V4 : Name_Id;
kono
parents:
diff changeset
1397 V5 : Name_Id;
kono
parents:
diff changeset
1398 V6 : Name_Id;
kono
parents:
diff changeset
1399 V7 : Name_Id;
kono
parents:
diff changeset
1400 V8 : Name_Id;
kono
parents:
diff changeset
1401 V9 : Name_Id;
kono
parents:
diff changeset
1402 V10 : Name_Id) return Boolean
kono
parents:
diff changeset
1403 is
kono
parents:
diff changeset
1404 begin
kono
parents:
diff changeset
1405 return T = V1 or else
kono
parents:
diff changeset
1406 T = V2 or else
kono
parents:
diff changeset
1407 T = V3 or else
kono
parents:
diff changeset
1408 T = V4 or else
kono
parents:
diff changeset
1409 T = V5 or else
kono
parents:
diff changeset
1410 T = V6 or else
kono
parents:
diff changeset
1411 T = V7 or else
kono
parents:
diff changeset
1412 T = V8 or else
kono
parents:
diff changeset
1413 T = V9 or else
kono
parents:
diff changeset
1414 T = V10;
kono
parents:
diff changeset
1415 end Nam_In;
kono
parents:
diff changeset
1416
kono
parents:
diff changeset
1417 function Nam_In
kono
parents:
diff changeset
1418 (T : Name_Id;
kono
parents:
diff changeset
1419 V1 : Name_Id;
kono
parents:
diff changeset
1420 V2 : Name_Id;
kono
parents:
diff changeset
1421 V3 : Name_Id;
kono
parents:
diff changeset
1422 V4 : Name_Id;
kono
parents:
diff changeset
1423 V5 : Name_Id;
kono
parents:
diff changeset
1424 V6 : Name_Id;
kono
parents:
diff changeset
1425 V7 : Name_Id;
kono
parents:
diff changeset
1426 V8 : Name_Id;
kono
parents:
diff changeset
1427 V9 : Name_Id;
kono
parents:
diff changeset
1428 V10 : Name_Id;
kono
parents:
diff changeset
1429 V11 : Name_Id) return Boolean
kono
parents:
diff changeset
1430 is
kono
parents:
diff changeset
1431 begin
kono
parents:
diff changeset
1432 return T = V1 or else
kono
parents:
diff changeset
1433 T = V2 or else
kono
parents:
diff changeset
1434 T = V3 or else
kono
parents:
diff changeset
1435 T = V4 or else
kono
parents:
diff changeset
1436 T = V5 or else
kono
parents:
diff changeset
1437 T = V6 or else
kono
parents:
diff changeset
1438 T = V7 or else
kono
parents:
diff changeset
1439 T = V8 or else
kono
parents:
diff changeset
1440 T = V9 or else
kono
parents:
diff changeset
1441 T = V10 or else
kono
parents:
diff changeset
1442 T = V11;
kono
parents:
diff changeset
1443 end Nam_In;
kono
parents:
diff changeset
1444
kono
parents:
diff changeset
1445 function Nam_In
kono
parents:
diff changeset
1446 (T : Name_Id;
kono
parents:
diff changeset
1447 V1 : Name_Id;
kono
parents:
diff changeset
1448 V2 : Name_Id;
kono
parents:
diff changeset
1449 V3 : Name_Id;
kono
parents:
diff changeset
1450 V4 : Name_Id;
kono
parents:
diff changeset
1451 V5 : Name_Id;
kono
parents:
diff changeset
1452 V6 : Name_Id;
kono
parents:
diff changeset
1453 V7 : Name_Id;
kono
parents:
diff changeset
1454 V8 : Name_Id;
kono
parents:
diff changeset
1455 V9 : Name_Id;
kono
parents:
diff changeset
1456 V10 : Name_Id;
kono
parents:
diff changeset
1457 V11 : Name_Id;
kono
parents:
diff changeset
1458 V12 : Name_Id) return Boolean
kono
parents:
diff changeset
1459 is
kono
parents:
diff changeset
1460 begin
kono
parents:
diff changeset
1461 return T = V1 or else
kono
parents:
diff changeset
1462 T = V2 or else
kono
parents:
diff changeset
1463 T = V3 or else
kono
parents:
diff changeset
1464 T = V4 or else
kono
parents:
diff changeset
1465 T = V5 or else
kono
parents:
diff changeset
1466 T = V6 or else
kono
parents:
diff changeset
1467 T = V7 or else
kono
parents:
diff changeset
1468 T = V8 or else
kono
parents:
diff changeset
1469 T = V9 or else
kono
parents:
diff changeset
1470 T = V10 or else
kono
parents:
diff changeset
1471 T = V11 or else
kono
parents:
diff changeset
1472 T = V12;
kono
parents:
diff changeset
1473 end Nam_In;
kono
parents:
diff changeset
1474
kono
parents:
diff changeset
1475 -----------------
kono
parents:
diff changeset
1476 -- Name_Equals --
kono
parents:
diff changeset
1477 -----------------
kono
parents:
diff changeset
1478
kono
parents:
diff changeset
1479 function Name_Equals (N1 : Name_Id; N2 : Name_Id) return Boolean is
kono
parents:
diff changeset
1480 begin
kono
parents:
diff changeset
1481 return N1 = N2 or else Get_Name_String (N1) = Get_Name_String (N2);
kono
parents:
diff changeset
1482 end Name_Equals;
kono
parents:
diff changeset
1483
kono
parents:
diff changeset
1484 ------------------
kono
parents:
diff changeset
1485 -- Reinitialize --
kono
parents:
diff changeset
1486 ------------------
kono
parents:
diff changeset
1487
kono
parents:
diff changeset
1488 procedure Reinitialize is
kono
parents:
diff changeset
1489 begin
kono
parents:
diff changeset
1490 Name_Chars.Init;
kono
parents:
diff changeset
1491 Name_Entries.Init;
kono
parents:
diff changeset
1492
kono
parents:
diff changeset
1493 -- Initialize entries for one character names
kono
parents:
diff changeset
1494
kono
parents:
diff changeset
1495 for C in Character loop
kono
parents:
diff changeset
1496 Name_Entries.Append
kono
parents:
diff changeset
1497 ((Name_Chars_Index => Name_Chars.Last,
kono
parents:
diff changeset
1498 Name_Len => 1,
kono
parents:
diff changeset
1499 Byte_Info => 0,
kono
parents:
diff changeset
1500 Int_Info => 0,
kono
parents:
diff changeset
1501 Boolean1_Info => False,
kono
parents:
diff changeset
1502 Boolean2_Info => False,
kono
parents:
diff changeset
1503 Boolean3_Info => False,
kono
parents:
diff changeset
1504 Name_Has_No_Encodings => True,
kono
parents:
diff changeset
1505 Hash_Link => No_Name));
kono
parents:
diff changeset
1506
kono
parents:
diff changeset
1507 Name_Chars.Append (C);
kono
parents:
diff changeset
1508 Name_Chars.Append (ASCII.NUL);
kono
parents:
diff changeset
1509 end loop;
kono
parents:
diff changeset
1510
kono
parents:
diff changeset
1511 -- Clear hash table
kono
parents:
diff changeset
1512
kono
parents:
diff changeset
1513 for J in Hash_Index_Type loop
kono
parents:
diff changeset
1514 Hash_Table (J) := No_Name;
kono
parents:
diff changeset
1515 end loop;
kono
parents:
diff changeset
1516 end Reinitialize;
kono
parents:
diff changeset
1517
kono
parents:
diff changeset
1518 ----------------------
kono
parents:
diff changeset
1519 -- Reset_Name_Table --
kono
parents:
diff changeset
1520 ----------------------
kono
parents:
diff changeset
1521
kono
parents:
diff changeset
1522 procedure Reset_Name_Table is
kono
parents:
diff changeset
1523 begin
kono
parents:
diff changeset
1524 for J in First_Name_Id .. Name_Entries.Last loop
kono
parents:
diff changeset
1525 Name_Entries.Table (J).Int_Info := 0;
kono
parents:
diff changeset
1526 Name_Entries.Table (J).Byte_Info := 0;
kono
parents:
diff changeset
1527 end loop;
kono
parents:
diff changeset
1528 end Reset_Name_Table;
kono
parents:
diff changeset
1529
kono
parents:
diff changeset
1530 --------------------------------
kono
parents:
diff changeset
1531 -- Set_Character_Literal_Name --
kono
parents:
diff changeset
1532 --------------------------------
kono
parents:
diff changeset
1533
kono
parents:
diff changeset
1534 procedure Set_Character_Literal_Name
kono
parents:
diff changeset
1535 (Buf : in out Bounded_String;
kono
parents:
diff changeset
1536 C : Char_Code)
kono
parents:
diff changeset
1537 is
kono
parents:
diff changeset
1538 begin
kono
parents:
diff changeset
1539 Buf.Length := 0;
kono
parents:
diff changeset
1540 Append (Buf, 'Q');
kono
parents:
diff changeset
1541 Append_Encoded (Buf, C);
kono
parents:
diff changeset
1542 end Set_Character_Literal_Name;
kono
parents:
diff changeset
1543
kono
parents:
diff changeset
1544 procedure Set_Character_Literal_Name (C : Char_Code) is
kono
parents:
diff changeset
1545 begin
kono
parents:
diff changeset
1546 Set_Character_Literal_Name (Global_Name_Buffer, C);
kono
parents:
diff changeset
1547 end Set_Character_Literal_Name;
kono
parents:
diff changeset
1548
kono
parents:
diff changeset
1549 -----------------------------
kono
parents:
diff changeset
1550 -- Set_Name_Table_Boolean1 --
kono
parents:
diff changeset
1551 -----------------------------
kono
parents:
diff changeset
1552
kono
parents:
diff changeset
1553 procedure Set_Name_Table_Boolean1 (Id : Name_Id; Val : Boolean) is
kono
parents:
diff changeset
1554 begin
kono
parents:
diff changeset
1555 pragma Assert (Id in Name_Entries.First .. Name_Entries.Last);
kono
parents:
diff changeset
1556 Name_Entries.Table (Id).Boolean1_Info := Val;
kono
parents:
diff changeset
1557 end Set_Name_Table_Boolean1;
kono
parents:
diff changeset
1558
kono
parents:
diff changeset
1559 -----------------------------
kono
parents:
diff changeset
1560 -- Set_Name_Table_Boolean2 --
kono
parents:
diff changeset
1561 -----------------------------
kono
parents:
diff changeset
1562
kono
parents:
diff changeset
1563 procedure Set_Name_Table_Boolean2 (Id : Name_Id; Val : Boolean) is
kono
parents:
diff changeset
1564 begin
kono
parents:
diff changeset
1565 pragma Assert (Id in Name_Entries.First .. Name_Entries.Last);
kono
parents:
diff changeset
1566 Name_Entries.Table (Id).Boolean2_Info := Val;
kono
parents:
diff changeset
1567 end Set_Name_Table_Boolean2;
kono
parents:
diff changeset
1568
kono
parents:
diff changeset
1569 -----------------------------
kono
parents:
diff changeset
1570 -- Set_Name_Table_Boolean3 --
kono
parents:
diff changeset
1571 -----------------------------
kono
parents:
diff changeset
1572
kono
parents:
diff changeset
1573 procedure Set_Name_Table_Boolean3 (Id : Name_Id; Val : Boolean) is
kono
parents:
diff changeset
1574 begin
kono
parents:
diff changeset
1575 pragma Assert (Id in Name_Entries.First .. Name_Entries.Last);
kono
parents:
diff changeset
1576 Name_Entries.Table (Id).Boolean3_Info := Val;
kono
parents:
diff changeset
1577 end Set_Name_Table_Boolean3;
kono
parents:
diff changeset
1578
kono
parents:
diff changeset
1579 -------------------------
kono
parents:
diff changeset
1580 -- Set_Name_Table_Byte --
kono
parents:
diff changeset
1581 -------------------------
kono
parents:
diff changeset
1582
kono
parents:
diff changeset
1583 procedure Set_Name_Table_Byte (Id : Name_Id; Val : Byte) is
kono
parents:
diff changeset
1584 begin
kono
parents:
diff changeset
1585 pragma Assert (Id in Name_Entries.First .. Name_Entries.Last);
kono
parents:
diff changeset
1586 Name_Entries.Table (Id).Byte_Info := Val;
kono
parents:
diff changeset
1587 end Set_Name_Table_Byte;
kono
parents:
diff changeset
1588
kono
parents:
diff changeset
1589 -------------------------
kono
parents:
diff changeset
1590 -- Set_Name_Table_Int --
kono
parents:
diff changeset
1591 -------------------------
kono
parents:
diff changeset
1592
kono
parents:
diff changeset
1593 procedure Set_Name_Table_Int (Id : Name_Id; Val : Int) is
kono
parents:
diff changeset
1594 begin
kono
parents:
diff changeset
1595 pragma Assert (Id in Name_Entries.First .. Name_Entries.Last);
kono
parents:
diff changeset
1596 Name_Entries.Table (Id).Int_Info := Val;
kono
parents:
diff changeset
1597 end Set_Name_Table_Int;
kono
parents:
diff changeset
1598
kono
parents:
diff changeset
1599 -----------------------------
kono
parents:
diff changeset
1600 -- Store_Encoded_Character --
kono
parents:
diff changeset
1601 -----------------------------
kono
parents:
diff changeset
1602
kono
parents:
diff changeset
1603 procedure Store_Encoded_Character (C : Char_Code) is
kono
parents:
diff changeset
1604 begin
kono
parents:
diff changeset
1605 Append_Encoded (Global_Name_Buffer, C);
kono
parents:
diff changeset
1606 end Store_Encoded_Character;
kono
parents:
diff changeset
1607
kono
parents:
diff changeset
1608 --------------------------------------
kono
parents:
diff changeset
1609 -- Strip_Qualification_And_Suffixes --
kono
parents:
diff changeset
1610 --------------------------------------
kono
parents:
diff changeset
1611
kono
parents:
diff changeset
1612 procedure Strip_Qualification_And_Suffixes (Buf : in out Bounded_String) is
kono
parents:
diff changeset
1613 J : Integer;
kono
parents:
diff changeset
1614
kono
parents:
diff changeset
1615 begin
kono
parents:
diff changeset
1616 -- Strip package body qualification string off end
kono
parents:
diff changeset
1617
kono
parents:
diff changeset
1618 for J in reverse 2 .. Buf.Length loop
kono
parents:
diff changeset
1619 if Buf.Chars (J) = 'X' then
kono
parents:
diff changeset
1620 Buf.Length := J - 1;
kono
parents:
diff changeset
1621 exit;
kono
parents:
diff changeset
1622 end if;
kono
parents:
diff changeset
1623
kono
parents:
diff changeset
1624 exit when Buf.Chars (J) /= 'b'
kono
parents:
diff changeset
1625 and then Buf.Chars (J) /= 'n'
kono
parents:
diff changeset
1626 and then Buf.Chars (J) /= 'p';
kono
parents:
diff changeset
1627 end loop;
kono
parents:
diff changeset
1628
kono
parents:
diff changeset
1629 -- Find rightmost __ or $ separator if one exists. First we position
kono
parents:
diff changeset
1630 -- to start the search. If we have a character constant, position
kono
parents:
diff changeset
1631 -- just before it, otherwise position to last character but one
kono
parents:
diff changeset
1632
kono
parents:
diff changeset
1633 if Buf.Chars (Buf.Length) = ''' then
kono
parents:
diff changeset
1634 J := Buf.Length - 2;
kono
parents:
diff changeset
1635 while J > 0 and then Buf.Chars (J) /= ''' loop
kono
parents:
diff changeset
1636 J := J - 1;
kono
parents:
diff changeset
1637 end loop;
kono
parents:
diff changeset
1638
kono
parents:
diff changeset
1639 else
kono
parents:
diff changeset
1640 J := Buf.Length - 1;
kono
parents:
diff changeset
1641 end if;
kono
parents:
diff changeset
1642
kono
parents:
diff changeset
1643 -- Loop to search for rightmost __ or $ (homonym) separator
kono
parents:
diff changeset
1644
kono
parents:
diff changeset
1645 while J > 1 loop
kono
parents:
diff changeset
1646
kono
parents:
diff changeset
1647 -- If $ separator, homonym separator, so strip it and keep looking
kono
parents:
diff changeset
1648
kono
parents:
diff changeset
1649 if Buf.Chars (J) = '$' then
kono
parents:
diff changeset
1650 Buf.Length := J - 1;
kono
parents:
diff changeset
1651 J := Buf.Length - 1;
kono
parents:
diff changeset
1652
kono
parents:
diff changeset
1653 -- Else check for __ found
kono
parents:
diff changeset
1654
kono
parents:
diff changeset
1655 elsif Buf.Chars (J) = '_' and then Buf.Chars (J + 1) = '_' then
kono
parents:
diff changeset
1656
kono
parents:
diff changeset
1657 -- Found __ so see if digit follows, and if so, this is a
kono
parents:
diff changeset
1658 -- homonym separator, so strip it and keep looking.
kono
parents:
diff changeset
1659
kono
parents:
diff changeset
1660 if Buf.Chars (J + 2) in '0' .. '9' then
kono
parents:
diff changeset
1661 Buf.Length := J - 1;
kono
parents:
diff changeset
1662 J := Buf.Length - 1;
kono
parents:
diff changeset
1663
kono
parents:
diff changeset
1664 -- If not a homonym separator, then we simply strip the
kono
parents:
diff changeset
1665 -- separator and everything that precedes it, and we are done
kono
parents:
diff changeset
1666
kono
parents:
diff changeset
1667 else
kono
parents:
diff changeset
1668 Buf.Chars (1 .. Buf.Length - J - 1) :=
kono
parents:
diff changeset
1669 Buf.Chars (J + 2 .. Buf.Length);
kono
parents:
diff changeset
1670 Buf.Length := Buf.Length - J - 1;
kono
parents:
diff changeset
1671 exit;
kono
parents:
diff changeset
1672 end if;
kono
parents:
diff changeset
1673
kono
parents:
diff changeset
1674 else
kono
parents:
diff changeset
1675 J := J - 1;
kono
parents:
diff changeset
1676 end if;
kono
parents:
diff changeset
1677 end loop;
kono
parents:
diff changeset
1678 end Strip_Qualification_And_Suffixes;
kono
parents:
diff changeset
1679
kono
parents:
diff changeset
1680 ---------------
kono
parents:
diff changeset
1681 -- To_String --
kono
parents:
diff changeset
1682 ---------------
kono
parents:
diff changeset
1683
kono
parents:
diff changeset
1684 function To_String (Buf : Bounded_String) return String is
kono
parents:
diff changeset
1685 begin
kono
parents:
diff changeset
1686 return Buf.Chars (1 .. Buf.Length);
kono
parents:
diff changeset
1687 end To_String;
kono
parents:
diff changeset
1688
kono
parents:
diff changeset
1689 ---------------
kono
parents:
diff changeset
1690 -- Tree_Read --
kono
parents:
diff changeset
1691 ---------------
kono
parents:
diff changeset
1692
kono
parents:
diff changeset
1693 procedure Tree_Read is
kono
parents:
diff changeset
1694 begin
kono
parents:
diff changeset
1695 Name_Chars.Tree_Read;
kono
parents:
diff changeset
1696 Name_Entries.Tree_Read;
kono
parents:
diff changeset
1697
kono
parents:
diff changeset
1698 Tree_Read_Data
kono
parents:
diff changeset
1699 (Hash_Table'Address,
kono
parents:
diff changeset
1700 Hash_Table'Length * (Hash_Table'Component_Size / Storage_Unit));
kono
parents:
diff changeset
1701 end Tree_Read;
kono
parents:
diff changeset
1702
kono
parents:
diff changeset
1703 ----------------
kono
parents:
diff changeset
1704 -- Tree_Write --
kono
parents:
diff changeset
1705 ----------------
kono
parents:
diff changeset
1706
kono
parents:
diff changeset
1707 procedure Tree_Write is
kono
parents:
diff changeset
1708 begin
kono
parents:
diff changeset
1709 Name_Chars.Tree_Write;
kono
parents:
diff changeset
1710 Name_Entries.Tree_Write;
kono
parents:
diff changeset
1711
kono
parents:
diff changeset
1712 Tree_Write_Data
kono
parents:
diff changeset
1713 (Hash_Table'Address,
kono
parents:
diff changeset
1714 Hash_Table'Length * (Hash_Table'Component_Size / Storage_Unit));
kono
parents:
diff changeset
1715 end Tree_Write;
kono
parents:
diff changeset
1716
kono
parents:
diff changeset
1717 ------------
kono
parents:
diff changeset
1718 -- Unlock --
kono
parents:
diff changeset
1719 ------------
kono
parents:
diff changeset
1720
kono
parents:
diff changeset
1721 procedure Unlock is
kono
parents:
diff changeset
1722 begin
kono
parents:
diff changeset
1723 Name_Chars.Locked := False;
kono
parents:
diff changeset
1724 Name_Chars.Set_Last (Name_Chars.Last - Name_Chars_Reserve);
kono
parents:
diff changeset
1725 Name_Chars.Release;
kono
parents:
diff changeset
1726 Name_Entries.Locked := False;
kono
parents:
diff changeset
1727 Name_Entries.Set_Last (Name_Entries.Last - Name_Entries_Reserve);
kono
parents:
diff changeset
1728 Name_Entries.Release;
kono
parents:
diff changeset
1729 end Unlock;
kono
parents:
diff changeset
1730
kono
parents:
diff changeset
1731 --------
kono
parents:
diff changeset
1732 -- wn --
kono
parents:
diff changeset
1733 --------
kono
parents:
diff changeset
1734
kono
parents:
diff changeset
1735 procedure wn (Id : Name_Id) is
kono
parents:
diff changeset
1736 begin
kono
parents:
diff changeset
1737 if Id not in Name_Entries.First .. Name_Entries.Last then
kono
parents:
diff changeset
1738 Write_Str ("<invalid name_id>");
kono
parents:
diff changeset
1739
kono
parents:
diff changeset
1740 elsif Id = No_Name then
kono
parents:
diff changeset
1741 Write_Str ("<No_Name>");
kono
parents:
diff changeset
1742
kono
parents:
diff changeset
1743 elsif Id = Error_Name then
kono
parents:
diff changeset
1744 Write_Str ("<Error_Name>");
kono
parents:
diff changeset
1745
kono
parents:
diff changeset
1746 else
kono
parents:
diff changeset
1747 declare
kono
parents:
diff changeset
1748 Buf : Bounded_String (Max_Length => Natural (Length_Of_Name (Id)));
kono
parents:
diff changeset
1749 begin
kono
parents:
diff changeset
1750 Append (Buf, Id);
kono
parents:
diff changeset
1751 Write_Str (Buf.Chars (1 .. Buf.Length));
kono
parents:
diff changeset
1752 end;
kono
parents:
diff changeset
1753 end if;
kono
parents:
diff changeset
1754
kono
parents:
diff changeset
1755 Write_Eol;
kono
parents:
diff changeset
1756 end wn;
kono
parents:
diff changeset
1757
kono
parents:
diff changeset
1758 ----------------
kono
parents:
diff changeset
1759 -- Write_Name --
kono
parents:
diff changeset
1760 ----------------
kono
parents:
diff changeset
1761
kono
parents:
diff changeset
1762 procedure Write_Name (Id : Name_Id) is
kono
parents:
diff changeset
1763 Buf : Bounded_String (Max_Length => Natural (Length_Of_Name (Id)));
kono
parents:
diff changeset
1764 begin
kono
parents:
diff changeset
1765 if Id >= First_Name_Id then
kono
parents:
diff changeset
1766 Append (Buf, Id);
kono
parents:
diff changeset
1767 Write_Str (Buf.Chars (1 .. Buf.Length));
kono
parents:
diff changeset
1768 end if;
kono
parents:
diff changeset
1769 end Write_Name;
kono
parents:
diff changeset
1770
kono
parents:
diff changeset
1771 ------------------------
kono
parents:
diff changeset
1772 -- Write_Name_Decoded --
kono
parents:
diff changeset
1773 ------------------------
kono
parents:
diff changeset
1774
kono
parents:
diff changeset
1775 procedure Write_Name_Decoded (Id : Name_Id) is
kono
parents:
diff changeset
1776 Buf : Bounded_String;
kono
parents:
diff changeset
1777 begin
kono
parents:
diff changeset
1778 if Id >= First_Name_Id then
kono
parents:
diff changeset
1779 Append_Decoded (Buf, Id);
kono
parents:
diff changeset
1780 Write_Str (Buf.Chars (1 .. Buf.Length));
kono
parents:
diff changeset
1781 end if;
kono
parents:
diff changeset
1782 end Write_Name_Decoded;
kono
parents:
diff changeset
1783
kono
parents:
diff changeset
1784 -- Package initialization, initialize tables
kono
parents:
diff changeset
1785
kono
parents:
diff changeset
1786 begin
kono
parents:
diff changeset
1787 Reinitialize;
kono
parents:
diff changeset
1788 end Namet;