annotate gcc/ada/get_scos.adb @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children 1830386684a0
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 -- G E T _ S C O S --
kono
parents:
diff changeset
6 -- --
kono
parents:
diff changeset
7 -- B o d y --
kono
parents:
diff changeset
8 -- --
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
9 -- Copyright (C) 2009-2018, Free Software Foundation, Inc. --
111
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. See the GNU General Public License --
kono
parents:
diff changeset
17 -- for more details. You should have received a copy of the GNU General --
kono
parents:
diff changeset
18 -- Public License distributed with GNAT; see file COPYING3. If not, go to --
kono
parents:
diff changeset
19 -- http://www.gnu.org/licenses for a complete copy of the license. --
kono
parents:
diff changeset
20 -- --
kono
parents:
diff changeset
21 -- GNAT was originally developed by the GNAT team at New York University. --
kono
parents:
diff changeset
22 -- Extensive contributions were provided by Ada Core Technologies Inc. --
kono
parents:
diff changeset
23 -- --
kono
parents:
diff changeset
24 ------------------------------------------------------------------------------
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 pragma Ada_2005;
kono
parents:
diff changeset
27 -- This unit is not part of the compiler proper, it is used in tools that
kono
parents:
diff changeset
28 -- read SCO information from ALI files (Xcov and sco_test). Ada 2005
kono
parents:
diff changeset
29 -- constructs may therefore be used freely (and are indeed).
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 with Namet; use Namet;
kono
parents:
diff changeset
32 with SCOs; use SCOs;
kono
parents:
diff changeset
33 with Types; use Types;
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 with Ada.IO_Exceptions; use Ada.IO_Exceptions;
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 procedure Get_SCOs is
kono
parents:
diff changeset
38 Dnum : Nat;
kono
parents:
diff changeset
39 C : Character;
kono
parents:
diff changeset
40 Loc1 : Source_Location;
kono
parents:
diff changeset
41 Loc2 : Source_Location;
kono
parents:
diff changeset
42 Cond : Character;
kono
parents:
diff changeset
43 Dtyp : Character;
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 use ASCII;
kono
parents:
diff changeset
46 -- For CR/LF
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 function At_EOL return Boolean;
kono
parents:
diff changeset
49 -- Skips any spaces, then checks if we are the end of a line. If so,
kono
parents:
diff changeset
50 -- returns True (but does not skip over the EOL sequence). If not,
kono
parents:
diff changeset
51 -- then returns False.
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 procedure Check (C : Character);
kono
parents:
diff changeset
54 -- Checks that file is positioned at given character, and if so skips past
kono
parents:
diff changeset
55 -- it, If not, raises Data_Error.
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 function Get_Int return Int;
kono
parents:
diff changeset
58 -- On entry the file is positioned to a digit. On return, the file is
kono
parents:
diff changeset
59 -- positioned past the last digit, and the returned result is the decimal
kono
parents:
diff changeset
60 -- value read. Data_Error is raised for overflow (value greater than
kono
parents:
diff changeset
61 -- Int'Last), or if the initial character is not a digit.
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 procedure Get_Source_Location (Loc : out Source_Location);
kono
parents:
diff changeset
64 -- Reads a source location in the form line:col and places the source
kono
parents:
diff changeset
65 -- location in Loc. Raises Data_Error if the format does not match this
kono
parents:
diff changeset
66 -- requirement. Note that initial spaces are not skipped.
kono
parents:
diff changeset
67
kono
parents:
diff changeset
68 procedure Get_Source_Location_Range (Loc1, Loc2 : out Source_Location);
kono
parents:
diff changeset
69 -- Skips initial spaces, then reads a source location range in the form
kono
parents:
diff changeset
70 -- line:col-line:col and places the two source locations in Loc1 and Loc2.
kono
parents:
diff changeset
71 -- Raises Data_Error if format does not match this requirement.
kono
parents:
diff changeset
72
kono
parents:
diff changeset
73 procedure Skip_EOL;
kono
parents:
diff changeset
74 -- Called with the current character about to be read being LF or CR. Skips
kono
parents:
diff changeset
75 -- past CR/LF characters until either a non-CR/LF character is found, or
kono
parents:
diff changeset
76 -- the end of file is encountered.
kono
parents:
diff changeset
77
kono
parents:
diff changeset
78 procedure Skip_Spaces;
kono
parents:
diff changeset
79 -- Skips zero or more spaces at the current position, leaving the file
kono
parents:
diff changeset
80 -- positioned at the first non-blank character (or Types.EOF).
kono
parents:
diff changeset
81
kono
parents:
diff changeset
82 ------------
kono
parents:
diff changeset
83 -- At_EOL --
kono
parents:
diff changeset
84 ------------
kono
parents:
diff changeset
85
kono
parents:
diff changeset
86 function At_EOL return Boolean is
kono
parents:
diff changeset
87 begin
kono
parents:
diff changeset
88 Skip_Spaces;
kono
parents:
diff changeset
89 return Nextc = CR or else Nextc = LF;
kono
parents:
diff changeset
90 end At_EOL;
kono
parents:
diff changeset
91
kono
parents:
diff changeset
92 -----------
kono
parents:
diff changeset
93 -- Check --
kono
parents:
diff changeset
94 -----------
kono
parents:
diff changeset
95
kono
parents:
diff changeset
96 procedure Check (C : Character) is
kono
parents:
diff changeset
97 begin
kono
parents:
diff changeset
98 if Nextc = C then
kono
parents:
diff changeset
99 Skipc;
kono
parents:
diff changeset
100 else
kono
parents:
diff changeset
101 raise Data_Error;
kono
parents:
diff changeset
102 end if;
kono
parents:
diff changeset
103 end Check;
kono
parents:
diff changeset
104
kono
parents:
diff changeset
105 -------------
kono
parents:
diff changeset
106 -- Get_Int --
kono
parents:
diff changeset
107 -------------
kono
parents:
diff changeset
108
kono
parents:
diff changeset
109 function Get_Int return Int is
kono
parents:
diff changeset
110 Val : Int;
kono
parents:
diff changeset
111 C : Character;
kono
parents:
diff changeset
112
kono
parents:
diff changeset
113 begin
kono
parents:
diff changeset
114 C := Nextc;
kono
parents:
diff changeset
115 Val := 0;
kono
parents:
diff changeset
116
kono
parents:
diff changeset
117 if C not in '0' .. '9' then
kono
parents:
diff changeset
118 raise Data_Error;
kono
parents:
diff changeset
119 end if;
kono
parents:
diff changeset
120
kono
parents:
diff changeset
121 -- Loop to read digits of integer value
kono
parents:
diff changeset
122
kono
parents:
diff changeset
123 loop
kono
parents:
diff changeset
124 declare
kono
parents:
diff changeset
125 pragma Unsuppress (Overflow_Check);
kono
parents:
diff changeset
126 begin
kono
parents:
diff changeset
127 Val := Val * 10 + (Character'Pos (C) - Character'Pos ('0'));
kono
parents:
diff changeset
128 end;
kono
parents:
diff changeset
129
kono
parents:
diff changeset
130 Skipc;
kono
parents:
diff changeset
131 C := Nextc;
kono
parents:
diff changeset
132
kono
parents:
diff changeset
133 exit when C not in '0' .. '9';
kono
parents:
diff changeset
134 end loop;
kono
parents:
diff changeset
135
kono
parents:
diff changeset
136 return Val;
kono
parents:
diff changeset
137
kono
parents:
diff changeset
138 exception
kono
parents:
diff changeset
139 when Constraint_Error =>
kono
parents:
diff changeset
140 raise Data_Error;
kono
parents:
diff changeset
141 end Get_Int;
kono
parents:
diff changeset
142
kono
parents:
diff changeset
143 -------------------------
kono
parents:
diff changeset
144 -- Get_Source_Location --
kono
parents:
diff changeset
145 -------------------------
kono
parents:
diff changeset
146
kono
parents:
diff changeset
147 procedure Get_Source_Location (Loc : out Source_Location) is
kono
parents:
diff changeset
148 pragma Unsuppress (Range_Check);
kono
parents:
diff changeset
149 begin
kono
parents:
diff changeset
150 Loc.Line := Logical_Line_Number (Get_Int);
kono
parents:
diff changeset
151 Check (':');
kono
parents:
diff changeset
152 Loc.Col := Column_Number (Get_Int);
kono
parents:
diff changeset
153 exception
kono
parents:
diff changeset
154 when Constraint_Error =>
kono
parents:
diff changeset
155 raise Data_Error;
kono
parents:
diff changeset
156 end Get_Source_Location;
kono
parents:
diff changeset
157
kono
parents:
diff changeset
158 -------------------------------
kono
parents:
diff changeset
159 -- Get_Source_Location_Range --
kono
parents:
diff changeset
160 -------------------------------
kono
parents:
diff changeset
161
kono
parents:
diff changeset
162 procedure Get_Source_Location_Range (Loc1, Loc2 : out Source_Location) is
kono
parents:
diff changeset
163 begin
kono
parents:
diff changeset
164 Skip_Spaces;
kono
parents:
diff changeset
165 Get_Source_Location (Loc1);
kono
parents:
diff changeset
166 Check ('-');
kono
parents:
diff changeset
167 Get_Source_Location (Loc2);
kono
parents:
diff changeset
168 end Get_Source_Location_Range;
kono
parents:
diff changeset
169
kono
parents:
diff changeset
170 --------------
kono
parents:
diff changeset
171 -- Skip_EOL --
kono
parents:
diff changeset
172 --------------
kono
parents:
diff changeset
173
kono
parents:
diff changeset
174 procedure Skip_EOL is
kono
parents:
diff changeset
175 C : Character;
kono
parents:
diff changeset
176
kono
parents:
diff changeset
177 begin
kono
parents:
diff changeset
178 loop
kono
parents:
diff changeset
179 Skipc;
kono
parents:
diff changeset
180 C := Nextc;
kono
parents:
diff changeset
181 exit when C /= LF and then C /= CR;
kono
parents:
diff changeset
182
kono
parents:
diff changeset
183 if C = ' ' then
kono
parents:
diff changeset
184 Skip_Spaces;
kono
parents:
diff changeset
185 C := Nextc;
kono
parents:
diff changeset
186 exit when C /= LF and then C /= CR;
kono
parents:
diff changeset
187 end if;
kono
parents:
diff changeset
188 end loop;
kono
parents:
diff changeset
189 end Skip_EOL;
kono
parents:
diff changeset
190
kono
parents:
diff changeset
191 -----------------
kono
parents:
diff changeset
192 -- Skip_Spaces --
kono
parents:
diff changeset
193 -----------------
kono
parents:
diff changeset
194
kono
parents:
diff changeset
195 procedure Skip_Spaces is
kono
parents:
diff changeset
196 begin
kono
parents:
diff changeset
197 while Nextc = ' ' loop
kono
parents:
diff changeset
198 Skipc;
kono
parents:
diff changeset
199 end loop;
kono
parents:
diff changeset
200 end Skip_Spaces;
kono
parents:
diff changeset
201
kono
parents:
diff changeset
202 Buf : String (1 .. 32_768);
kono
parents:
diff changeset
203 N : Natural;
kono
parents:
diff changeset
204 -- Scratch buffer, and index into it
kono
parents:
diff changeset
205
kono
parents:
diff changeset
206 Nam : Name_Id;
kono
parents:
diff changeset
207
kono
parents:
diff changeset
208 -- Start of processing for Get_SCOs
kono
parents:
diff changeset
209
kono
parents:
diff changeset
210 begin
kono
parents:
diff changeset
211 SCOs.Initialize;
kono
parents:
diff changeset
212
kono
parents:
diff changeset
213 -- Loop through lines of SCO information
kono
parents:
diff changeset
214
kono
parents:
diff changeset
215 while Nextc = 'C' loop
kono
parents:
diff changeset
216 Skipc;
kono
parents:
diff changeset
217
kono
parents:
diff changeset
218 C := Getc;
kono
parents:
diff changeset
219
kono
parents:
diff changeset
220 -- Make sure first line is a header line
kono
parents:
diff changeset
221
kono
parents:
diff changeset
222 if SCO_Unit_Table.Last = 0 and then C /= ' ' then
kono
parents:
diff changeset
223 raise Data_Error;
kono
parents:
diff changeset
224 end if;
kono
parents:
diff changeset
225
kono
parents:
diff changeset
226 -- Otherwise dispatch on type of line
kono
parents:
diff changeset
227
kono
parents:
diff changeset
228 case C is
kono
parents:
diff changeset
229
kono
parents:
diff changeset
230 -- Header or instance table entry
kono
parents:
diff changeset
231
kono
parents:
diff changeset
232 when ' ' =>
kono
parents:
diff changeset
233
kono
parents:
diff changeset
234 -- Complete previous entry if any
kono
parents:
diff changeset
235
kono
parents:
diff changeset
236 if SCO_Unit_Table.Last /= 0 then
kono
parents:
diff changeset
237 SCO_Unit_Table.Table (SCO_Unit_Table.Last).To :=
kono
parents:
diff changeset
238 SCO_Table.Last;
kono
parents:
diff changeset
239 end if;
kono
parents:
diff changeset
240
kono
parents:
diff changeset
241 Skip_Spaces;
kono
parents:
diff changeset
242
kono
parents:
diff changeset
243 case Nextc is
kono
parents:
diff changeset
244
kono
parents:
diff changeset
245 -- Instance table entry
kono
parents:
diff changeset
246
kono
parents:
diff changeset
247 when 'i' =>
kono
parents:
diff changeset
248 declare
kono
parents:
diff changeset
249 Inum : SCO_Instance_Index;
kono
parents:
diff changeset
250 begin
kono
parents:
diff changeset
251 Skipc;
kono
parents:
diff changeset
252 Skip_Spaces;
kono
parents:
diff changeset
253
kono
parents:
diff changeset
254 Inum := SCO_Instance_Index (Get_Int);
kono
parents:
diff changeset
255 SCO_Instance_Table.Increment_Last;
kono
parents:
diff changeset
256 pragma Assert (SCO_Instance_Table.Last = Inum);
kono
parents:
diff changeset
257
kono
parents:
diff changeset
258 Skip_Spaces;
kono
parents:
diff changeset
259 declare
kono
parents:
diff changeset
260 SIE : SCO_Instance_Table_Entry
kono
parents:
diff changeset
261 renames SCO_Instance_Table.Table (Inum);
kono
parents:
diff changeset
262 begin
kono
parents:
diff changeset
263 SIE.Inst_Dep_Num := Get_Int;
kono
parents:
diff changeset
264 C := Getc;
kono
parents:
diff changeset
265 pragma Assert (C = '|');
kono
parents:
diff changeset
266 Get_Source_Location (SIE.Inst_Loc);
kono
parents:
diff changeset
267
kono
parents:
diff changeset
268 if At_EOL then
kono
parents:
diff changeset
269 SIE.Enclosing_Instance := 0;
kono
parents:
diff changeset
270 else
kono
parents:
diff changeset
271 Skip_Spaces;
kono
parents:
diff changeset
272 SIE.Enclosing_Instance :=
kono
parents:
diff changeset
273 SCO_Instance_Index (Get_Int);
kono
parents:
diff changeset
274 pragma Assert (SIE.Enclosing_Instance in
kono
parents:
diff changeset
275 SCO_Instance_Table.First
kono
parents:
diff changeset
276 .. SCO_Instance_Table.Last);
kono
parents:
diff changeset
277 end if;
kono
parents:
diff changeset
278 end;
kono
parents:
diff changeset
279 end;
kono
parents:
diff changeset
280
kono
parents:
diff changeset
281 -- Unit header
kono
parents:
diff changeset
282
kono
parents:
diff changeset
283 when '0' .. '9' =>
kono
parents:
diff changeset
284 -- Scan out dependency number and file name
kono
parents:
diff changeset
285
kono
parents:
diff changeset
286 Dnum := Get_Int;
kono
parents:
diff changeset
287
kono
parents:
diff changeset
288 Skip_Spaces;
kono
parents:
diff changeset
289
kono
parents:
diff changeset
290 N := 0;
kono
parents:
diff changeset
291 while Nextc > ' ' loop
kono
parents:
diff changeset
292 N := N + 1;
kono
parents:
diff changeset
293 Buf (N) := Getc;
kono
parents:
diff changeset
294 end loop;
kono
parents:
diff changeset
295
kono
parents:
diff changeset
296 -- Make new unit table entry (will fill in To later)
kono
parents:
diff changeset
297
kono
parents:
diff changeset
298 SCO_Unit_Table.Append (
kono
parents:
diff changeset
299 (File_Name => new String'(Buf (1 .. N)),
kono
parents:
diff changeset
300 File_Index => 0,
kono
parents:
diff changeset
301 Dep_Num => Dnum,
kono
parents:
diff changeset
302 From => SCO_Table.Last + 1,
kono
parents:
diff changeset
303 To => 0));
kono
parents:
diff changeset
304
kono
parents:
diff changeset
305 when others =>
kono
parents:
diff changeset
306 raise Program_Error;
kono
parents:
diff changeset
307 end case;
kono
parents:
diff changeset
308
kono
parents:
diff changeset
309 -- Statement entry
kono
parents:
diff changeset
310
kono
parents:
diff changeset
311 when 'S' | 's' =>
kono
parents:
diff changeset
312 declare
kono
parents:
diff changeset
313 Typ : Character;
kono
parents:
diff changeset
314 Key : Character;
kono
parents:
diff changeset
315
kono
parents:
diff changeset
316 begin
kono
parents:
diff changeset
317 Key := 'S';
kono
parents:
diff changeset
318
kono
parents:
diff changeset
319 -- If continuation, reset Last indication in last entry stored
kono
parents:
diff changeset
320 -- for previous CS or cs line.
kono
parents:
diff changeset
321
kono
parents:
diff changeset
322 if C = 's' then
kono
parents:
diff changeset
323 SCO_Table.Table (SCO_Table.Last).Last := False;
kono
parents:
diff changeset
324 end if;
kono
parents:
diff changeset
325
kono
parents:
diff changeset
326 -- Initialize to scan items on one line
kono
parents:
diff changeset
327
kono
parents:
diff changeset
328 Skip_Spaces;
kono
parents:
diff changeset
329
kono
parents:
diff changeset
330 -- Loop through items on one line
kono
parents:
diff changeset
331
kono
parents:
diff changeset
332 loop
kono
parents:
diff changeset
333 Nam := No_Name;
kono
parents:
diff changeset
334 Typ := Nextc;
kono
parents:
diff changeset
335
kono
parents:
diff changeset
336 case Typ is
kono
parents:
diff changeset
337 when '>' =>
kono
parents:
diff changeset
338
kono
parents:
diff changeset
339 -- Dominance marker may be present only at entry point
kono
parents:
diff changeset
340
kono
parents:
diff changeset
341 pragma Assert (Key = 'S');
kono
parents:
diff changeset
342
kono
parents:
diff changeset
343 Skipc;
kono
parents:
diff changeset
344 Key := '>';
kono
parents:
diff changeset
345 Typ := Getc;
kono
parents:
diff changeset
346
kono
parents:
diff changeset
347 -- Sanity check on dominance marker type indication
kono
parents:
diff changeset
348
kono
parents:
diff changeset
349 pragma Assert (Typ in 'A' .. 'Z');
kono
parents:
diff changeset
350
kono
parents:
diff changeset
351 when '1' .. '9' =>
kono
parents:
diff changeset
352 Typ := ' ';
kono
parents:
diff changeset
353
kono
parents:
diff changeset
354 when others =>
kono
parents:
diff changeset
355 Skipc;
kono
parents:
diff changeset
356 if Typ = 'P' or else Typ = 'p' then
kono
parents:
diff changeset
357 if Nextc not in '1' .. '9' then
kono
parents:
diff changeset
358 Name_Len := 0;
kono
parents:
diff changeset
359 loop
kono
parents:
diff changeset
360 Name_Len := Name_Len + 1;
kono
parents:
diff changeset
361 Name_Buffer (Name_Len) := Getc;
kono
parents:
diff changeset
362 exit when Nextc = ':';
kono
parents:
diff changeset
363 end loop;
kono
parents:
diff changeset
364
kono
parents:
diff changeset
365 Skipc; -- Past ':'
kono
parents:
diff changeset
366
kono
parents:
diff changeset
367 Nam := Name_Find;
kono
parents:
diff changeset
368 end if;
kono
parents:
diff changeset
369 end if;
kono
parents:
diff changeset
370 end case;
kono
parents:
diff changeset
371
kono
parents:
diff changeset
372 if Key = '>' and then Typ /= 'E' then
kono
parents:
diff changeset
373 Get_Source_Location (Loc1);
kono
parents:
diff changeset
374 Loc2 := No_Source_Location;
kono
parents:
diff changeset
375 else
kono
parents:
diff changeset
376 Get_Source_Location_Range (Loc1, Loc2);
kono
parents:
diff changeset
377 end if;
kono
parents:
diff changeset
378
kono
parents:
diff changeset
379 SCO_Table.Append
kono
parents:
diff changeset
380 ((C1 => Key,
kono
parents:
diff changeset
381 C2 => Typ,
kono
parents:
diff changeset
382 From => Loc1,
kono
parents:
diff changeset
383 To => Loc2,
kono
parents:
diff changeset
384 Last => At_EOL,
kono
parents:
diff changeset
385 Pragma_Sloc => No_Location,
kono
parents:
diff changeset
386 Pragma_Aspect_Name => Nam));
kono
parents:
diff changeset
387
kono
parents:
diff changeset
388 if Key = '>' then
kono
parents:
diff changeset
389 Key := 'S';
kono
parents:
diff changeset
390 end if;
kono
parents:
diff changeset
391
kono
parents:
diff changeset
392 exit when At_EOL;
kono
parents:
diff changeset
393 end loop;
kono
parents:
diff changeset
394 end;
kono
parents:
diff changeset
395
kono
parents:
diff changeset
396 -- Decision entry
kono
parents:
diff changeset
397
kono
parents:
diff changeset
398 when 'E' | 'G' | 'I' | 'P' | 'W' | 'X' | 'A' =>
kono
parents:
diff changeset
399 Dtyp := C;
kono
parents:
diff changeset
400
kono
parents:
diff changeset
401 if C = 'A' then
kono
parents:
diff changeset
402 Name_Len := 0;
kono
parents:
diff changeset
403 while Nextc /= ' ' loop
kono
parents:
diff changeset
404 Name_Len := Name_Len + 1;
kono
parents:
diff changeset
405 Name_Buffer (Name_Len) := Getc;
kono
parents:
diff changeset
406 end loop;
kono
parents:
diff changeset
407
kono
parents:
diff changeset
408 Nam := Name_Find;
kono
parents:
diff changeset
409
kono
parents:
diff changeset
410 else
kono
parents:
diff changeset
411 Nam := No_Name;
kono
parents:
diff changeset
412 end if;
kono
parents:
diff changeset
413
kono
parents:
diff changeset
414 Skip_Spaces;
kono
parents:
diff changeset
415
kono
parents:
diff changeset
416 -- Output header
kono
parents:
diff changeset
417
kono
parents:
diff changeset
418 declare
kono
parents:
diff changeset
419 Loc : Source_Location;
kono
parents:
diff changeset
420
kono
parents:
diff changeset
421 begin
kono
parents:
diff changeset
422 -- Acquire location information
kono
parents:
diff changeset
423
kono
parents:
diff changeset
424 if Dtyp = 'X' then
kono
parents:
diff changeset
425 Loc := No_Source_Location;
kono
parents:
diff changeset
426 else
kono
parents:
diff changeset
427 Get_Source_Location (Loc);
kono
parents:
diff changeset
428 end if;
kono
parents:
diff changeset
429
kono
parents:
diff changeset
430 SCO_Table.Append
kono
parents:
diff changeset
431 ((C1 => Dtyp,
kono
parents:
diff changeset
432 C2 => ' ',
kono
parents:
diff changeset
433 From => Loc,
kono
parents:
diff changeset
434 To => No_Source_Location,
kono
parents:
diff changeset
435 Last => False,
kono
parents:
diff changeset
436 Pragma_Aspect_Name => Nam,
kono
parents:
diff changeset
437 others => <>));
kono
parents:
diff changeset
438 end;
kono
parents:
diff changeset
439
kono
parents:
diff changeset
440 -- Loop through terms in complex expression
kono
parents:
diff changeset
441
kono
parents:
diff changeset
442 C := Nextc;
kono
parents:
diff changeset
443 while C /= CR and then C /= LF loop
kono
parents:
diff changeset
444 if C = 'c' or else C = 't' or else C = 'f' then
kono
parents:
diff changeset
445 Cond := C;
kono
parents:
diff changeset
446 Skipc;
kono
parents:
diff changeset
447 Get_Source_Location_Range (Loc1, Loc2);
kono
parents:
diff changeset
448 SCO_Table.Append
kono
parents:
diff changeset
449 ((C2 => Cond,
kono
parents:
diff changeset
450 From => Loc1,
kono
parents:
diff changeset
451 To => Loc2,
kono
parents:
diff changeset
452 Last => False,
kono
parents:
diff changeset
453 others => <>));
kono
parents:
diff changeset
454
kono
parents:
diff changeset
455 elsif C = '!' or else
kono
parents:
diff changeset
456 C = '&' or else
kono
parents:
diff changeset
457 C = '|'
kono
parents:
diff changeset
458 then
kono
parents:
diff changeset
459 Skipc;
kono
parents:
diff changeset
460
kono
parents:
diff changeset
461 declare
kono
parents:
diff changeset
462 Loc : Source_Location;
kono
parents:
diff changeset
463 begin
kono
parents:
diff changeset
464 Get_Source_Location (Loc);
kono
parents:
diff changeset
465 SCO_Table.Append
kono
parents:
diff changeset
466 ((C1 => C,
kono
parents:
diff changeset
467 From => Loc,
kono
parents:
diff changeset
468 Last => False,
kono
parents:
diff changeset
469 others => <>));
kono
parents:
diff changeset
470 end;
kono
parents:
diff changeset
471
kono
parents:
diff changeset
472 elsif C = ' ' then
kono
parents:
diff changeset
473 Skip_Spaces;
kono
parents:
diff changeset
474
kono
parents:
diff changeset
475 elsif C = 'T' or else C = 'F' then
kono
parents:
diff changeset
476
kono
parents:
diff changeset
477 -- Chaining indicator: skip for now???
kono
parents:
diff changeset
478
kono
parents:
diff changeset
479 declare
kono
parents:
diff changeset
480 Loc1, Loc2 : Source_Location;
kono
parents:
diff changeset
481 pragma Unreferenced (Loc1, Loc2);
kono
parents:
diff changeset
482 begin
kono
parents:
diff changeset
483 Skipc;
kono
parents:
diff changeset
484 Get_Source_Location_Range (Loc1, Loc2);
kono
parents:
diff changeset
485 end;
kono
parents:
diff changeset
486
kono
parents:
diff changeset
487 else
kono
parents:
diff changeset
488 raise Data_Error;
kono
parents:
diff changeset
489 end if;
kono
parents:
diff changeset
490
kono
parents:
diff changeset
491 C := Nextc;
kono
parents:
diff changeset
492 end loop;
kono
parents:
diff changeset
493
kono
parents:
diff changeset
494 -- Reset Last indication to True for last entry
kono
parents:
diff changeset
495
kono
parents:
diff changeset
496 SCO_Table.Table (SCO_Table.Last).Last := True;
kono
parents:
diff changeset
497
kono
parents:
diff changeset
498 -- No other SCO lines are possible
kono
parents:
diff changeset
499
kono
parents:
diff changeset
500 when others =>
kono
parents:
diff changeset
501 raise Data_Error;
kono
parents:
diff changeset
502 end case;
kono
parents:
diff changeset
503
kono
parents:
diff changeset
504 Skip_EOL;
kono
parents:
diff changeset
505 end loop;
kono
parents:
diff changeset
506
kono
parents:
diff changeset
507 -- Here with all SCO's stored, complete last SCO Unit table entry
kono
parents:
diff changeset
508
kono
parents:
diff changeset
509 SCO_Unit_Table.Table (SCO_Unit_Table.Last).To := SCO_Table.Last;
kono
parents:
diff changeset
510 end Get_SCOs;