annotate gcc/ada/switch-c.adb @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents 84e7813d76e9
children
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 -- S W I T C H - C --
kono
parents:
diff changeset
6 -- --
kono
parents:
diff changeset
7 -- B o d y --
kono
parents:
diff changeset
8 -- --
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
9 -- Copyright (C) 2001-2019, 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 -- This package is for switch processing and should not depend on higher level
kono
parents:
diff changeset
27 -- packages such as those for the scanner, parser, etc. Doing so may cause
kono
parents:
diff changeset
28 -- circularities, especially for back ends using Adabkend.
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 with Debug; use Debug;
kono
parents:
diff changeset
31 with Errout; use Errout;
kono
parents:
diff changeset
32 with Lib; use Lib;
kono
parents:
diff changeset
33 with Osint; use Osint;
kono
parents:
diff changeset
34 with Opt; use Opt;
kono
parents:
diff changeset
35 with Stylesw; use Stylesw;
kono
parents:
diff changeset
36 with Targparm; use Targparm;
kono
parents:
diff changeset
37 with Ttypes; use Ttypes;
kono
parents:
diff changeset
38 with Validsw; use Validsw;
kono
parents:
diff changeset
39 with Warnsw; use Warnsw;
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 with Ada.Unchecked_Deallocation;
kono
parents:
diff changeset
42
kono
parents:
diff changeset
43 with System.WCh_Con; use System.WCh_Con;
kono
parents:
diff changeset
44 with System.OS_Lib;
kono
parents:
diff changeset
45
kono
parents:
diff changeset
46 package body Switch.C is
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 RTS_Specified : String_Access := null;
kono
parents:
diff changeset
49 -- Used to detect multiple use of --RTS= flag
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 procedure Add_Symbol_Definition (Def : String);
kono
parents:
diff changeset
52 -- Add a symbol definition from the command line
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 procedure Free is
kono
parents:
diff changeset
55 new Ada.Unchecked_Deallocation (String_List, String_List_Access);
kono
parents:
diff changeset
56 -- Avoid using System.Strings.Free, which also frees the designated strings
kono
parents:
diff changeset
57
kono
parents:
diff changeset
58 function Get_Overflow_Mode (C : Character) return Overflow_Mode_Type;
kono
parents:
diff changeset
59 -- Given a digit in the range 0 .. 3, returns the corresponding value of
kono
parents:
diff changeset
60 -- Overflow_Mode_Type. Raises Program_Error if C is outside this range.
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 function Switch_Subsequently_Cancelled
kono
parents:
diff changeset
63 (C : String;
kono
parents:
diff changeset
64 Args : String_List;
kono
parents:
diff changeset
65 Arg_Rank : Positive) return Boolean;
kono
parents:
diff changeset
66 -- This function is called from Scan_Front_End_Switches. It determines if
kono
parents:
diff changeset
67 -- the switch currently being scanned is followed by a switch of the form
kono
parents:
diff changeset
68 -- "-gnat-" & C, where C is the argument. If so, then True is returned,
kono
parents:
diff changeset
69 -- and Scan_Front_End_Switches will cancel the effect of the switch. If
kono
parents:
diff changeset
70 -- no such switch is found, False is returned.
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72 ---------------------------
kono
parents:
diff changeset
73 -- Add_Symbol_Definition --
kono
parents:
diff changeset
74 ---------------------------
kono
parents:
diff changeset
75
kono
parents:
diff changeset
76 procedure Add_Symbol_Definition (Def : String) is
kono
parents:
diff changeset
77 begin
kono
parents:
diff changeset
78 -- If Preprocessor_Symbol_Defs is not large enough, double its size
kono
parents:
diff changeset
79
kono
parents:
diff changeset
80 if Preprocessing_Symbol_Last = Preprocessing_Symbol_Defs'Last then
kono
parents:
diff changeset
81 declare
kono
parents:
diff changeset
82 New_Symbol_Definitions : constant String_List_Access :=
kono
parents:
diff changeset
83 new String_List (1 .. 2 * Preprocessing_Symbol_Last);
kono
parents:
diff changeset
84 begin
kono
parents:
diff changeset
85 New_Symbol_Definitions (Preprocessing_Symbol_Defs'Range) :=
kono
parents:
diff changeset
86 Preprocessing_Symbol_Defs.all;
kono
parents:
diff changeset
87 Free (Preprocessing_Symbol_Defs);
kono
parents:
diff changeset
88 Preprocessing_Symbol_Defs := New_Symbol_Definitions;
kono
parents:
diff changeset
89 end;
kono
parents:
diff changeset
90 end if;
kono
parents:
diff changeset
91
kono
parents:
diff changeset
92 Preprocessing_Symbol_Last := Preprocessing_Symbol_Last + 1;
kono
parents:
diff changeset
93 Preprocessing_Symbol_Defs (Preprocessing_Symbol_Last) :=
kono
parents:
diff changeset
94 new String'(Def);
kono
parents:
diff changeset
95 end Add_Symbol_Definition;
kono
parents:
diff changeset
96
kono
parents:
diff changeset
97 -----------------------
kono
parents:
diff changeset
98 -- Get_Overflow_Mode --
kono
parents:
diff changeset
99 -----------------------
kono
parents:
diff changeset
100
kono
parents:
diff changeset
101 function Get_Overflow_Mode (C : Character) return Overflow_Mode_Type is
kono
parents:
diff changeset
102 begin
kono
parents:
diff changeset
103 case C is
kono
parents:
diff changeset
104 when '1' =>
kono
parents:
diff changeset
105 return Strict;
kono
parents:
diff changeset
106
kono
parents:
diff changeset
107 when '2' =>
kono
parents:
diff changeset
108 return Minimized;
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 -- Eliminated allowed only if Long_Long_Integer is 64 bits (since
kono
parents:
diff changeset
111 -- the current implementation of System.Bignums assumes this).
kono
parents:
diff changeset
112
kono
parents:
diff changeset
113 when '3' =>
kono
parents:
diff changeset
114 if Standard_Long_Long_Integer_Size /= 64 then
kono
parents:
diff changeset
115 Bad_Switch ("-gnato3 not implemented for this configuration");
kono
parents:
diff changeset
116 else
kono
parents:
diff changeset
117 return Eliminated;
kono
parents:
diff changeset
118 end if;
kono
parents:
diff changeset
119
kono
parents:
diff changeset
120 when others =>
kono
parents:
diff changeset
121 raise Program_Error;
kono
parents:
diff changeset
122 end case;
kono
parents:
diff changeset
123 end Get_Overflow_Mode;
kono
parents:
diff changeset
124
kono
parents:
diff changeset
125 -----------------------------
kono
parents:
diff changeset
126 -- Scan_Front_End_Switches --
kono
parents:
diff changeset
127 -----------------------------
kono
parents:
diff changeset
128
kono
parents:
diff changeset
129 procedure Scan_Front_End_Switches
kono
parents:
diff changeset
130 (Switch_Chars : String;
kono
parents:
diff changeset
131 Args : String_List;
kono
parents:
diff changeset
132 Arg_Rank : Positive)
kono
parents:
diff changeset
133 is
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
134 Max : constant Natural := Switch_Chars'Last;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
135 C : Character := ' ';
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
136 Ptr : Natural;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
137
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
138 Dot : Boolean;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
139 -- This flag is set upon encountering a dot in a debug switch
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
140
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
141 First_Char : Positive;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
142 -- Marks start of switch to be stored
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
143
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
144 First_Ptr : Positive;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
145 -- Save position of first character after -gnatd (for checking that
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
146 -- debug flags that must come first are first, in particular -gnatd.b).
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
147
111
kono
parents:
diff changeset
148 First_Switch : Boolean := True;
kono
parents:
diff changeset
149 -- False for all but first switch
kono
parents:
diff changeset
150
kono
parents:
diff changeset
151 Store_Switch : Boolean;
kono
parents:
diff changeset
152 -- For -gnatxx switches, the normal processing, signalled by this flag
kono
parents:
diff changeset
153 -- being set to True, is to store the switch on exit from the case
kono
parents:
diff changeset
154 -- statement, the switch stored is -gnat followed by the characters
kono
parents:
diff changeset
155 -- from First_Char to Ptr-1. For cases like -gnaty, where the switch
kono
parents:
diff changeset
156 -- is stored in separate pieces, this flag is set to False, and the
kono
parents:
diff changeset
157 -- appropriate calls to Store_Compilation_Switch are made from within
kono
parents:
diff changeset
158 -- the case branch.
kono
parents:
diff changeset
159
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
160 Underscore : Boolean;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
161 -- This flag is set upon encountering an underscode in a debug switch
111
kono
parents:
diff changeset
162
kono
parents:
diff changeset
163 begin
kono
parents:
diff changeset
164 Ptr := Switch_Chars'First;
kono
parents:
diff changeset
165
kono
parents:
diff changeset
166 -- Skip past the initial character (must be the switch character)
kono
parents:
diff changeset
167
kono
parents:
diff changeset
168 if Ptr = Max then
kono
parents:
diff changeset
169 Bad_Switch (C);
kono
parents:
diff changeset
170 else
kono
parents:
diff changeset
171 Ptr := Ptr + 1;
kono
parents:
diff changeset
172 end if;
kono
parents:
diff changeset
173
kono
parents:
diff changeset
174 -- Handle switches that do not start with -gnat
kono
parents:
diff changeset
175
kono
parents:
diff changeset
176 if Ptr + 3 > Max or else Switch_Chars (Ptr .. Ptr + 3) /= "gnat" then
kono
parents:
diff changeset
177
kono
parents:
diff changeset
178 -- There are two front-end switches that do not start with -gnat:
kono
parents:
diff changeset
179 -- -I, --RTS
kono
parents:
diff changeset
180
kono
parents:
diff changeset
181 if Switch_Chars (Ptr) = 'I' then
kono
parents:
diff changeset
182
kono
parents:
diff changeset
183 -- Set flag Search_Directory_Present if switch is "-I" only:
kono
parents:
diff changeset
184 -- the directory will be the next argument.
kono
parents:
diff changeset
185
kono
parents:
diff changeset
186 if Ptr = Max then
kono
parents:
diff changeset
187 Search_Directory_Present := True;
kono
parents:
diff changeset
188 return;
kono
parents:
diff changeset
189 end if;
kono
parents:
diff changeset
190
kono
parents:
diff changeset
191 Ptr := Ptr + 1;
kono
parents:
diff changeset
192
kono
parents:
diff changeset
193 -- Find out whether this is a -I- or regular -Ixxx switch
kono
parents:
diff changeset
194
kono
parents:
diff changeset
195 -- Note: -I switches are not recorded in the ALI file, since the
kono
parents:
diff changeset
196 -- meaning of the program depends on the source files compiled,
kono
parents:
diff changeset
197 -- not where they came from.
kono
parents:
diff changeset
198
kono
parents:
diff changeset
199 if Ptr = Max and then Switch_Chars (Ptr) = '-' then
kono
parents:
diff changeset
200 Look_In_Primary_Dir := False;
kono
parents:
diff changeset
201 else
kono
parents:
diff changeset
202 Add_Src_Search_Dir (Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
203 end if;
kono
parents:
diff changeset
204
kono
parents:
diff changeset
205 -- Processing of the --RTS switch. --RTS may have been modified by
kono
parents:
diff changeset
206 -- gcc into -fRTS (for GCC targets).
kono
parents:
diff changeset
207
kono
parents:
diff changeset
208 elsif Ptr + 3 <= Max
kono
parents:
diff changeset
209 and then (Switch_Chars (Ptr .. Ptr + 3) = "fRTS"
kono
parents:
diff changeset
210 or else
kono
parents:
diff changeset
211 Switch_Chars (Ptr .. Ptr + 3) = "-RTS")
kono
parents:
diff changeset
212 then
kono
parents:
diff changeset
213 Ptr := Ptr + 1;
kono
parents:
diff changeset
214
kono
parents:
diff changeset
215 if Ptr + 4 > Max
kono
parents:
diff changeset
216 or else Switch_Chars (Ptr + 3) /= '='
kono
parents:
diff changeset
217 then
kono
parents:
diff changeset
218 Osint.Fail ("missing path for --RTS");
kono
parents:
diff changeset
219
kono
parents:
diff changeset
220 else
kono
parents:
diff changeset
221 declare
kono
parents:
diff changeset
222 Runtime_Dir : String_Access;
kono
parents:
diff changeset
223 begin
kono
parents:
diff changeset
224 if System.OS_Lib.Is_Absolute_Path
kono
parents:
diff changeset
225 (Switch_Chars (Ptr + 4 .. Max))
kono
parents:
diff changeset
226 then
kono
parents:
diff changeset
227 Runtime_Dir :=
kono
parents:
diff changeset
228 new String'(System.OS_Lib.Normalize_Pathname
kono
parents:
diff changeset
229 (Switch_Chars (Ptr + 4 .. Max)));
kono
parents:
diff changeset
230 else
kono
parents:
diff changeset
231 Runtime_Dir :=
kono
parents:
diff changeset
232 new String'(Switch_Chars (Ptr + 4 .. Max));
kono
parents:
diff changeset
233 end if;
kono
parents:
diff changeset
234
kono
parents:
diff changeset
235 -- Valid --RTS switch
kono
parents:
diff changeset
236
kono
parents:
diff changeset
237 Opt.No_Stdinc := True;
kono
parents:
diff changeset
238 Opt.RTS_Switch := True;
kono
parents:
diff changeset
239
kono
parents:
diff changeset
240 RTS_Src_Path_Name :=
kono
parents:
diff changeset
241 Get_RTS_Search_Dir (Runtime_Dir.all, Include);
kono
parents:
diff changeset
242
kono
parents:
diff changeset
243 RTS_Lib_Path_Name :=
kono
parents:
diff changeset
244 Get_RTS_Search_Dir (Runtime_Dir.all, Objects);
kono
parents:
diff changeset
245
kono
parents:
diff changeset
246 if RTS_Specified /= null then
kono
parents:
diff changeset
247 if RTS_Src_Path_Name = null
kono
parents:
diff changeset
248 or else RTS_Lib_Path_Name = null
kono
parents:
diff changeset
249 or else
kono
parents:
diff changeset
250 System.OS_Lib.Normalize_Pathname
kono
parents:
diff changeset
251 (RTS_Specified.all) /=
kono
parents:
diff changeset
252 System.OS_Lib.Normalize_Pathname
kono
parents:
diff changeset
253 (RTS_Lib_Path_Name.all)
kono
parents:
diff changeset
254 then
kono
parents:
diff changeset
255 Osint.Fail
kono
parents:
diff changeset
256 ("--RTS cannot be specified multiple times");
kono
parents:
diff changeset
257 end if;
kono
parents:
diff changeset
258
kono
parents:
diff changeset
259 elsif RTS_Src_Path_Name /= null
kono
parents:
diff changeset
260 and then RTS_Lib_Path_Name /= null
kono
parents:
diff changeset
261 then
kono
parents:
diff changeset
262 -- Store the -fRTS switch (Note: Store_Compilation_Switch
kono
parents:
diff changeset
263 -- changes -fRTS back into --RTS for the actual output).
kono
parents:
diff changeset
264
kono
parents:
diff changeset
265 Store_Compilation_Switch (Switch_Chars);
kono
parents:
diff changeset
266 RTS_Specified := new String'(RTS_Lib_Path_Name.all);
kono
parents:
diff changeset
267
kono
parents:
diff changeset
268 elsif RTS_Src_Path_Name = null
kono
parents:
diff changeset
269 and then RTS_Lib_Path_Name = null
kono
parents:
diff changeset
270 then
kono
parents:
diff changeset
271 Osint.Fail ("RTS path not valid: missing "
kono
parents:
diff changeset
272 & "adainclude and adalib directories");
kono
parents:
diff changeset
273
kono
parents:
diff changeset
274 elsif RTS_Src_Path_Name = null then
kono
parents:
diff changeset
275 Osint.Fail ("RTS path not valid: missing "
kono
parents:
diff changeset
276 & "adainclude directory");
kono
parents:
diff changeset
277
kono
parents:
diff changeset
278 elsif RTS_Lib_Path_Name = null then
kono
parents:
diff changeset
279 Osint.Fail ("RTS path not valid: missing "
kono
parents:
diff changeset
280 & "adalib directory");
kono
parents:
diff changeset
281 end if;
kono
parents:
diff changeset
282 end;
kono
parents:
diff changeset
283 end if;
kono
parents:
diff changeset
284
kono
parents:
diff changeset
285 -- There are no other switches not starting with -gnat
kono
parents:
diff changeset
286
kono
parents:
diff changeset
287 else
kono
parents:
diff changeset
288 Bad_Switch (Switch_Chars);
kono
parents:
diff changeset
289 end if;
kono
parents:
diff changeset
290
kono
parents:
diff changeset
291 -- Case of switch starting with -gnat
kono
parents:
diff changeset
292
kono
parents:
diff changeset
293 else
kono
parents:
diff changeset
294 Ptr := Ptr + 4;
kono
parents:
diff changeset
295
kono
parents:
diff changeset
296 -- Loop to scan through switches given in switch string
kono
parents:
diff changeset
297
kono
parents:
diff changeset
298 while Ptr <= Max loop
kono
parents:
diff changeset
299 First_Char := Ptr;
kono
parents:
diff changeset
300 Store_Switch := True;
kono
parents:
diff changeset
301
kono
parents:
diff changeset
302 C := Switch_Chars (Ptr);
kono
parents:
diff changeset
303
kono
parents:
diff changeset
304 case C is
kono
parents:
diff changeset
305
kono
parents:
diff changeset
306 -- -gnata (assertions enabled)
kono
parents:
diff changeset
307
kono
parents:
diff changeset
308 when 'a' =>
kono
parents:
diff changeset
309 Ptr := Ptr + 1;
kono
parents:
diff changeset
310 Assertions_Enabled := True;
kono
parents:
diff changeset
311
kono
parents:
diff changeset
312 -- -gnatA (disregard gnat.adc)
kono
parents:
diff changeset
313
kono
parents:
diff changeset
314 when 'A' =>
kono
parents:
diff changeset
315 Ptr := Ptr + 1;
kono
parents:
diff changeset
316 Config_File := False;
kono
parents:
diff changeset
317
kono
parents:
diff changeset
318 -- -gnatb (brief messages to stderr)
kono
parents:
diff changeset
319
kono
parents:
diff changeset
320 when 'b' =>
kono
parents:
diff changeset
321 Ptr := Ptr + 1;
kono
parents:
diff changeset
322 Brief_Output := True;
kono
parents:
diff changeset
323
kono
parents:
diff changeset
324 -- -gnatB (assume no invalid values)
kono
parents:
diff changeset
325
kono
parents:
diff changeset
326 when 'B' =>
kono
parents:
diff changeset
327 Ptr := Ptr + 1;
kono
parents:
diff changeset
328 Assume_No_Invalid_Values := True;
kono
parents:
diff changeset
329
kono
parents:
diff changeset
330 -- -gnatc (check syntax and semantics only)
kono
parents:
diff changeset
331
kono
parents:
diff changeset
332 when 'c' =>
kono
parents:
diff changeset
333 if not First_Switch then
kono
parents:
diff changeset
334 Osint.Fail
kono
parents:
diff changeset
335 ("-gnatc must be first if combined with other switches");
kono
parents:
diff changeset
336 end if;
kono
parents:
diff changeset
337
kono
parents:
diff changeset
338 Ptr := Ptr + 1;
kono
parents:
diff changeset
339 Operating_Mode := Check_Semantics;
kono
parents:
diff changeset
340
kono
parents:
diff changeset
341 -- -gnatC (Generate CodePeer information)
kono
parents:
diff changeset
342
kono
parents:
diff changeset
343 when 'C' =>
kono
parents:
diff changeset
344 Ptr := Ptr + 1;
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
345 CodePeer_Mode := True;
111
kono
parents:
diff changeset
346
kono
parents:
diff changeset
347 -- -gnatd (compiler debug options)
kono
parents:
diff changeset
348
kono
parents:
diff changeset
349 when 'd' =>
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
350 Dot := False;
111
kono
parents:
diff changeset
351 Store_Switch := False;
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
352 Underscore := False;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
353
111
kono
parents:
diff changeset
354 First_Ptr := Ptr + 1;
kono
parents:
diff changeset
355
kono
parents:
diff changeset
356 -- Note: for the debug switch, the remaining characters in this
kono
parents:
diff changeset
357 -- switch field must all be debug flags, since all valid switch
kono
parents:
diff changeset
358 -- characters are also valid debug characters.
kono
parents:
diff changeset
359
kono
parents:
diff changeset
360 -- Loop to scan out debug flags
kono
parents:
diff changeset
361
kono
parents:
diff changeset
362 while Ptr < Max loop
kono
parents:
diff changeset
363 Ptr := Ptr + 1;
kono
parents:
diff changeset
364 C := Switch_Chars (Ptr);
kono
parents:
diff changeset
365 exit when C = ASCII.NUL or else C = '/' or else C = '-';
kono
parents:
diff changeset
366
kono
parents:
diff changeset
367 if C in '1' .. '9' or else
kono
parents:
diff changeset
368 C in 'a' .. 'z' or else
kono
parents:
diff changeset
369 C in 'A' .. 'Z'
kono
parents:
diff changeset
370 then
kono
parents:
diff changeset
371 -- Case of dotted flag
kono
parents:
diff changeset
372
kono
parents:
diff changeset
373 if Dot then
kono
parents:
diff changeset
374 Set_Dotted_Debug_Flag (C);
kono
parents:
diff changeset
375 Store_Compilation_Switch ("-gnatd." & C);
kono
parents:
diff changeset
376
kono
parents:
diff changeset
377 -- Special check, -gnatd.b must come first
kono
parents:
diff changeset
378
kono
parents:
diff changeset
379 if C = 'b'
kono
parents:
diff changeset
380 and then (Ptr /= First_Ptr + 1
kono
parents:
diff changeset
381 or else not First_Switch)
kono
parents:
diff changeset
382 then
kono
parents:
diff changeset
383 Osint.Fail
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
384 ("-gnatd.b must be first if combined with other "
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
385 & "switches");
111
kono
parents:
diff changeset
386 end if;
kono
parents:
diff changeset
387
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
388 -- Case of an underscored flag
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
389
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
390 elsif Underscore then
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
391 Set_Underscored_Debug_Flag (C);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
392 Store_Compilation_Switch ("-gnatd_" & C);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
393
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
394 -- Normal flag
111
kono
parents:
diff changeset
395
kono
parents:
diff changeset
396 else
kono
parents:
diff changeset
397 Set_Debug_Flag (C);
kono
parents:
diff changeset
398 Store_Compilation_Switch ("-gnatd" & C);
kono
parents:
diff changeset
399 end if;
kono
parents:
diff changeset
400
kono
parents:
diff changeset
401 elsif C = '.' then
kono
parents:
diff changeset
402 Dot := True;
kono
parents:
diff changeset
403
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
404 elsif C = '_' then
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
405 Underscore := True;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
406
111
kono
parents:
diff changeset
407 elsif Dot then
kono
parents:
diff changeset
408 Bad_Switch ("-gnatd." & Switch_Chars (Ptr .. Max));
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
409
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
410 elsif Underscore then
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
411 Bad_Switch ("-gnatd_" & Switch_Chars (Ptr .. Max));
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
412
111
kono
parents:
diff changeset
413 else
kono
parents:
diff changeset
414 Bad_Switch ("-gnatd" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
415 end if;
kono
parents:
diff changeset
416 end loop;
kono
parents:
diff changeset
417
kono
parents:
diff changeset
418 return;
kono
parents:
diff changeset
419
kono
parents:
diff changeset
420 -- -gnatD (debug expanded code)
kono
parents:
diff changeset
421
kono
parents:
diff changeset
422 when 'D' =>
kono
parents:
diff changeset
423 Ptr := Ptr + 1;
kono
parents:
diff changeset
424
kono
parents:
diff changeset
425 -- Not allowed if previous -gnatR given
kono
parents:
diff changeset
426
kono
parents:
diff changeset
427 -- The reason for this prohibition is that the rewriting of
kono
parents:
diff changeset
428 -- Sloc values causes strange malfunctions in the tests of
kono
parents:
diff changeset
429 -- whether units belong to the main source. This is really a
kono
parents:
diff changeset
430 -- bug, but too hard to fix for a marginal capability ???
kono
parents:
diff changeset
431
kono
parents:
diff changeset
432 -- The proper fix is to completely redo -gnatD processing so
kono
parents:
diff changeset
433 -- that the tree is not messed with, and instead a separate
kono
parents:
diff changeset
434 -- table is built on the side for debug information generation.
kono
parents:
diff changeset
435
kono
parents:
diff changeset
436 if List_Representation_Info /= 0 then
kono
parents:
diff changeset
437 Osint.Fail
kono
parents:
diff changeset
438 ("-gnatD not permitted since -gnatR given previously");
kono
parents:
diff changeset
439 end if;
kono
parents:
diff changeset
440
kono
parents:
diff changeset
441 -- Scan optional integer line limit value
kono
parents:
diff changeset
442
kono
parents:
diff changeset
443 if Nat_Present (Switch_Chars, Max, Ptr) then
kono
parents:
diff changeset
444 Scan_Nat (Switch_Chars, Max, Ptr, Sprint_Line_Limit, 'D');
kono
parents:
diff changeset
445 Sprint_Line_Limit := Nat'Max (Sprint_Line_Limit, 40);
kono
parents:
diff changeset
446 end if;
kono
parents:
diff changeset
447
kono
parents:
diff changeset
448 -- Note: -gnatD also sets -gnatx (to turn off cross-reference
kono
parents:
diff changeset
449 -- generation in the ali file) since otherwise this generation
kono
parents:
diff changeset
450 -- gets confused by the "wrong" Sloc values put in the tree.
kono
parents:
diff changeset
451
kono
parents:
diff changeset
452 Debug_Generated_Code := True;
kono
parents:
diff changeset
453 Xref_Active := False;
kono
parents:
diff changeset
454 Set_Debug_Flag ('g');
kono
parents:
diff changeset
455
kono
parents:
diff changeset
456 -- -gnate? (extended switches)
kono
parents:
diff changeset
457
kono
parents:
diff changeset
458 when 'e' =>
kono
parents:
diff changeset
459 Ptr := Ptr + 1;
kono
parents:
diff changeset
460
kono
parents:
diff changeset
461 -- The -gnate? switches are all double character switches
kono
parents:
diff changeset
462 -- so we must always have a character after the e.
kono
parents:
diff changeset
463
kono
parents:
diff changeset
464 if Ptr > Max then
kono
parents:
diff changeset
465 Bad_Switch ("-gnate");
kono
parents:
diff changeset
466 end if;
kono
parents:
diff changeset
467
kono
parents:
diff changeset
468 case Switch_Chars (Ptr) is
kono
parents:
diff changeset
469
kono
parents:
diff changeset
470 -- -gnatea (initial delimiter of explicit switches)
kono
parents:
diff changeset
471
kono
parents:
diff changeset
472 -- This is an internal switch
kono
parents:
diff changeset
473
kono
parents:
diff changeset
474 -- All switches that come before -gnatea have been added by
kono
parents:
diff changeset
475 -- the GCC driver and are not stored in the ALI file.
kono
parents:
diff changeset
476 -- See also -gnatez below.
kono
parents:
diff changeset
477
kono
parents:
diff changeset
478 when 'a' =>
kono
parents:
diff changeset
479 Store_Switch := False;
kono
parents:
diff changeset
480 Enable_Switch_Storing;
kono
parents:
diff changeset
481 Ptr := Ptr + 1;
kono
parents:
diff changeset
482
kono
parents:
diff changeset
483 -- -gnateA (aliasing checks on parameters)
kono
parents:
diff changeset
484
kono
parents:
diff changeset
485 when 'A' =>
kono
parents:
diff changeset
486 Ptr := Ptr + 1;
kono
parents:
diff changeset
487 Check_Aliasing_Of_Parameters := True;
kono
parents:
diff changeset
488
kono
parents:
diff changeset
489 -- -gnatec (configuration pragmas)
kono
parents:
diff changeset
490
kono
parents:
diff changeset
491 when 'c' =>
kono
parents:
diff changeset
492 Store_Switch := False;
kono
parents:
diff changeset
493 Ptr := Ptr + 1;
kono
parents:
diff changeset
494
kono
parents:
diff changeset
495 -- There may be an equal sign between -gnatec and
kono
parents:
diff changeset
496 -- the path name of the config file.
kono
parents:
diff changeset
497
kono
parents:
diff changeset
498 if Ptr <= Max and then Switch_Chars (Ptr) = '=' then
kono
parents:
diff changeset
499 Ptr := Ptr + 1;
kono
parents:
diff changeset
500 end if;
kono
parents:
diff changeset
501
kono
parents:
diff changeset
502 if Ptr > Max then
kono
parents:
diff changeset
503 Bad_Switch ("-gnatec");
kono
parents:
diff changeset
504 end if;
kono
parents:
diff changeset
505
kono
parents:
diff changeset
506 declare
kono
parents:
diff changeset
507 Config_File_Name : constant String_Access :=
kono
parents:
diff changeset
508 new String'
kono
parents:
diff changeset
509 (Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
510
kono
parents:
diff changeset
511 begin
kono
parents:
diff changeset
512 if Config_File_Names = null then
kono
parents:
diff changeset
513 Config_File_Names :=
kono
parents:
diff changeset
514 new String_List'(1 => Config_File_Name);
kono
parents:
diff changeset
515
kono
parents:
diff changeset
516 else
kono
parents:
diff changeset
517 declare
kono
parents:
diff changeset
518 New_Names : constant String_List_Access :=
kono
parents:
diff changeset
519 new String_List
kono
parents:
diff changeset
520 (1 ..
kono
parents:
diff changeset
521 Config_File_Names'Length + 1);
kono
parents:
diff changeset
522
kono
parents:
diff changeset
523 begin
kono
parents:
diff changeset
524 for Index in Config_File_Names'Range loop
kono
parents:
diff changeset
525 New_Names (Index) :=
kono
parents:
diff changeset
526 Config_File_Names (Index);
kono
parents:
diff changeset
527 Config_File_Names (Index) := null;
kono
parents:
diff changeset
528 end loop;
kono
parents:
diff changeset
529
kono
parents:
diff changeset
530 New_Names (New_Names'Last) := Config_File_Name;
kono
parents:
diff changeset
531 Free (Config_File_Names);
kono
parents:
diff changeset
532 Config_File_Names := New_Names;
kono
parents:
diff changeset
533 end;
kono
parents:
diff changeset
534 end if;
kono
parents:
diff changeset
535 end;
kono
parents:
diff changeset
536
kono
parents:
diff changeset
537 return;
kono
parents:
diff changeset
538
kono
parents:
diff changeset
539 -- -gnateC switch (generate CodePeer messages)
kono
parents:
diff changeset
540
kono
parents:
diff changeset
541 when 'C' =>
kono
parents:
diff changeset
542 Ptr := Ptr + 1;
kono
parents:
diff changeset
543
kono
parents:
diff changeset
544 if not Generate_CodePeer_Messages then
kono
parents:
diff changeset
545 Generate_CodePeer_Messages := True;
kono
parents:
diff changeset
546 CodePeer_Mode := True;
kono
parents:
diff changeset
547 Warning_Mode := Normal;
kono
parents:
diff changeset
548 Warning_Doc_Switch := True; -- -gnatw.d
kono
parents:
diff changeset
549
kono
parents:
diff changeset
550 -- Enable warnings potentially useful for non GNAT
kono
parents:
diff changeset
551 -- users.
kono
parents:
diff changeset
552
kono
parents:
diff changeset
553 Constant_Condition_Warnings := True; -- -gnatwc
kono
parents:
diff changeset
554 Warn_On_Assertion_Failure := True; -- -gnatw.a
kono
parents:
diff changeset
555 Warn_On_Assumed_Low_Bound := True; -- -gnatww
kono
parents:
diff changeset
556 Warn_On_Bad_Fixed_Value := True; -- -gnatwb
kono
parents:
diff changeset
557 Warn_On_Biased_Representation := True; -- -gnatw.b
kono
parents:
diff changeset
558 Warn_On_Export_Import := True; -- -gnatwx
kono
parents:
diff changeset
559 Warn_On_No_Value_Assigned := True; -- -gnatwv
kono
parents:
diff changeset
560 Warn_On_Object_Renames_Function := True; -- -gnatw.r
kono
parents:
diff changeset
561 Warn_On_Overlap := True; -- -gnatw.i
kono
parents:
diff changeset
562 Warn_On_Parameter_Order := True; -- -gnatw.p
kono
parents:
diff changeset
563 Warn_On_Questionable_Missing_Parens := True; -- -gnatwq
kono
parents:
diff changeset
564 Warn_On_Redundant_Constructs := True; -- -gnatwr
kono
parents:
diff changeset
565 Warn_On_Suspicious_Modulus_Value := True; -- -gnatw.m
kono
parents:
diff changeset
566 end if;
kono
parents:
diff changeset
567
kono
parents:
diff changeset
568 -- -gnated switch (disable atomic synchronization)
kono
parents:
diff changeset
569
kono
parents:
diff changeset
570 when 'd' =>
kono
parents:
diff changeset
571 Suppress_Options.Suppress (Atomic_Synchronization) :=
kono
parents:
diff changeset
572 True;
kono
parents:
diff changeset
573
kono
parents:
diff changeset
574 -- -gnateD switch (preprocessing symbol definition)
kono
parents:
diff changeset
575
kono
parents:
diff changeset
576 when 'D' =>
kono
parents:
diff changeset
577 Store_Switch := False;
kono
parents:
diff changeset
578 Ptr := Ptr + 1;
kono
parents:
diff changeset
579
kono
parents:
diff changeset
580 if Ptr > Max then
kono
parents:
diff changeset
581 Bad_Switch ("-gnateD");
kono
parents:
diff changeset
582 end if;
kono
parents:
diff changeset
583
kono
parents:
diff changeset
584 Add_Symbol_Definition (Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
585
kono
parents:
diff changeset
586 -- Store the switch
kono
parents:
diff changeset
587
kono
parents:
diff changeset
588 Store_Compilation_Switch
kono
parents:
diff changeset
589 ("-gnateD" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
590 Ptr := Max + 1;
kono
parents:
diff changeset
591
kono
parents:
diff changeset
592 -- -gnateE (extra exception information)
kono
parents:
diff changeset
593
kono
parents:
diff changeset
594 when 'E' =>
kono
parents:
diff changeset
595 Exception_Extra_Info := True;
kono
parents:
diff changeset
596 Ptr := Ptr + 1;
kono
parents:
diff changeset
597
kono
parents:
diff changeset
598 -- -gnatef (full source path for brief error messages)
kono
parents:
diff changeset
599
kono
parents:
diff changeset
600 when 'f' =>
kono
parents:
diff changeset
601 Store_Switch := False;
kono
parents:
diff changeset
602 Ptr := Ptr + 1;
kono
parents:
diff changeset
603 Full_Path_Name_For_Brief_Errors := True;
kono
parents:
diff changeset
604
kono
parents:
diff changeset
605 -- -gnateF (Check_Float_Overflow)
kono
parents:
diff changeset
606
kono
parents:
diff changeset
607 when 'F' =>
kono
parents:
diff changeset
608 Ptr := Ptr + 1;
kono
parents:
diff changeset
609 Check_Float_Overflow := not Machine_Overflows_On_Target;
kono
parents:
diff changeset
610
kono
parents:
diff changeset
611 -- -gnateg (generate C code)
kono
parents:
diff changeset
612
kono
parents:
diff changeset
613 when 'g' =>
kono
parents:
diff changeset
614 -- Special check, -gnateg must occur after -gnatc
kono
parents:
diff changeset
615
kono
parents:
diff changeset
616 if Operating_Mode /= Check_Semantics then
kono
parents:
diff changeset
617 Osint.Fail
kono
parents:
diff changeset
618 ("gnateg requires previous occurrence of -gnatc");
kono
parents:
diff changeset
619 end if;
kono
parents:
diff changeset
620
kono
parents:
diff changeset
621 Generate_C_Code := True;
kono
parents:
diff changeset
622 Ptr := Ptr + 1;
kono
parents:
diff changeset
623
kono
parents:
diff changeset
624 -- -gnateG (save preprocessor output)
kono
parents:
diff changeset
625
kono
parents:
diff changeset
626 when 'G' =>
kono
parents:
diff changeset
627 Generate_Processed_File := True;
kono
parents:
diff changeset
628 Ptr := Ptr + 1;
kono
parents:
diff changeset
629
kono
parents:
diff changeset
630 -- -gnatei (max number of instantiations)
kono
parents:
diff changeset
631
kono
parents:
diff changeset
632 when 'i' =>
kono
parents:
diff changeset
633 Ptr := Ptr + 1;
kono
parents:
diff changeset
634 Scan_Pos
kono
parents:
diff changeset
635 (Switch_Chars, Max, Ptr, Maximum_Instantiations, C);
kono
parents:
diff changeset
636
kono
parents:
diff changeset
637 -- -gnateI (index of unit in multi-unit source)
kono
parents:
diff changeset
638
kono
parents:
diff changeset
639 when 'I' =>
kono
parents:
diff changeset
640 Ptr := Ptr + 1;
kono
parents:
diff changeset
641 Scan_Pos (Switch_Chars, Max, Ptr, Multiple_Unit_Index, C);
kono
parents:
diff changeset
642
kono
parents:
diff changeset
643 -- -gnatel
kono
parents:
diff changeset
644
kono
parents:
diff changeset
645 when 'l' =>
kono
parents:
diff changeset
646 Ptr := Ptr + 1;
kono
parents:
diff changeset
647 Elab_Info_Messages := True;
kono
parents:
diff changeset
648
kono
parents:
diff changeset
649 -- -gnateL
kono
parents:
diff changeset
650
kono
parents:
diff changeset
651 when 'L' =>
kono
parents:
diff changeset
652 Ptr := Ptr + 1;
kono
parents:
diff changeset
653 Elab_Info_Messages := False;
kono
parents:
diff changeset
654
kono
parents:
diff changeset
655 -- -gnatem (mapping file)
kono
parents:
diff changeset
656
kono
parents:
diff changeset
657 when 'm' =>
kono
parents:
diff changeset
658 Store_Switch := False;
kono
parents:
diff changeset
659 Ptr := Ptr + 1;
kono
parents:
diff changeset
660
kono
parents:
diff changeset
661 -- There may be an equal sign between -gnatem and
kono
parents:
diff changeset
662 -- the path name of the mapping file.
kono
parents:
diff changeset
663
kono
parents:
diff changeset
664 if Ptr <= Max and then Switch_Chars (Ptr) = '=' then
kono
parents:
diff changeset
665 Ptr := Ptr + 1;
kono
parents:
diff changeset
666 end if;
kono
parents:
diff changeset
667
kono
parents:
diff changeset
668 if Ptr > Max then
kono
parents:
diff changeset
669 Bad_Switch ("-gnatem");
kono
parents:
diff changeset
670 end if;
kono
parents:
diff changeset
671
kono
parents:
diff changeset
672 Mapping_File_Name :=
kono
parents:
diff changeset
673 new String'(Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
674 return;
kono
parents:
diff changeset
675
kono
parents:
diff changeset
676 -- -gnateO= (object path file)
kono
parents:
diff changeset
677
kono
parents:
diff changeset
678 -- This is an internal switch
kono
parents:
diff changeset
679
kono
parents:
diff changeset
680 when 'O' =>
kono
parents:
diff changeset
681 Store_Switch := False;
kono
parents:
diff changeset
682 Ptr := Ptr + 1;
kono
parents:
diff changeset
683
kono
parents:
diff changeset
684 -- Check for '='
kono
parents:
diff changeset
685
kono
parents:
diff changeset
686 if Ptr >= Max or else Switch_Chars (Ptr) /= '=' then
kono
parents:
diff changeset
687 Bad_Switch ("-gnateO");
kono
parents:
diff changeset
688 else
kono
parents:
diff changeset
689 Object_Path_File_Name :=
kono
parents:
diff changeset
690 new String'(Switch_Chars (Ptr + 1 .. Max));
kono
parents:
diff changeset
691 end if;
kono
parents:
diff changeset
692
kono
parents:
diff changeset
693 return;
kono
parents:
diff changeset
694
kono
parents:
diff changeset
695 -- -gnatep (preprocessing data file)
kono
parents:
diff changeset
696
kono
parents:
diff changeset
697 when 'p' =>
kono
parents:
diff changeset
698 Store_Switch := False;
kono
parents:
diff changeset
699 Ptr := Ptr + 1;
kono
parents:
diff changeset
700
kono
parents:
diff changeset
701 -- There may be an equal sign between -gnatep and
kono
parents:
diff changeset
702 -- the path name of the mapping file.
kono
parents:
diff changeset
703
kono
parents:
diff changeset
704 if Ptr <= Max and then Switch_Chars (Ptr) = '=' then
kono
parents:
diff changeset
705 Ptr := Ptr + 1;
kono
parents:
diff changeset
706 end if;
kono
parents:
diff changeset
707
kono
parents:
diff changeset
708 if Ptr > Max then
kono
parents:
diff changeset
709 Bad_Switch ("-gnatep");
kono
parents:
diff changeset
710 end if;
kono
parents:
diff changeset
711
kono
parents:
diff changeset
712 Preprocessing_Data_File :=
kono
parents:
diff changeset
713 new String'(Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
714
kono
parents:
diff changeset
715 -- Store the switch, normalizing to -gnatep=
kono
parents:
diff changeset
716
kono
parents:
diff changeset
717 Store_Compilation_Switch
kono
parents:
diff changeset
718 ("-gnatep=" & Preprocessing_Data_File.all);
kono
parents:
diff changeset
719
kono
parents:
diff changeset
720 Ptr := Max + 1;
kono
parents:
diff changeset
721
kono
parents:
diff changeset
722 -- -gnateP (Treat pragma Pure/Preelaborate errs as warnings)
kono
parents:
diff changeset
723
kono
parents:
diff changeset
724 when 'P' =>
kono
parents:
diff changeset
725 Treat_Categorization_Errors_As_Warnings := True;
kono
parents:
diff changeset
726
kono
parents:
diff changeset
727 -- -gnates=file (specify extra file switches for gnat2why)
kono
parents:
diff changeset
728
kono
parents:
diff changeset
729 -- This is an internal switch
kono
parents:
diff changeset
730
kono
parents:
diff changeset
731 when 's' =>
kono
parents:
diff changeset
732 if not First_Switch then
kono
parents:
diff changeset
733 Osint.Fail
kono
parents:
diff changeset
734 ("-gnates must not be combined with other switches");
kono
parents:
diff changeset
735 end if;
kono
parents:
diff changeset
736
kono
parents:
diff changeset
737 -- Check for '='
kono
parents:
diff changeset
738
kono
parents:
diff changeset
739 Ptr := Ptr + 1;
kono
parents:
diff changeset
740
kono
parents:
diff changeset
741 if Ptr >= Max or else Switch_Chars (Ptr) /= '=' then
kono
parents:
diff changeset
742 Bad_Switch ("-gnates");
kono
parents:
diff changeset
743 else
kono
parents:
diff changeset
744 SPARK_Switches_File_Name :=
kono
parents:
diff changeset
745 new String'(Switch_Chars (Ptr + 1 .. Max));
kono
parents:
diff changeset
746 end if;
kono
parents:
diff changeset
747
kono
parents:
diff changeset
748 return;
kono
parents:
diff changeset
749
kono
parents:
diff changeset
750 -- -gnateS (generate SCO information)
kono
parents:
diff changeset
751
kono
parents:
diff changeset
752 -- Include Source Coverage Obligation information in ALI
kono
parents:
diff changeset
753 -- files for use by source coverage analysis tools
kono
parents:
diff changeset
754 -- (gnatcov) (equivalent to -fdump-scos, provided for
kono
parents:
diff changeset
755 -- backwards compatibility).
kono
parents:
diff changeset
756
kono
parents:
diff changeset
757 when 'S' =>
kono
parents:
diff changeset
758 Generate_SCO := True;
kono
parents:
diff changeset
759 Generate_SCO_Instance_Table := True;
kono
parents:
diff changeset
760 Ptr := Ptr + 1;
kono
parents:
diff changeset
761
kono
parents:
diff changeset
762 -- -gnatet (write target dependent information)
kono
parents:
diff changeset
763
kono
parents:
diff changeset
764 when 't' =>
kono
parents:
diff changeset
765 if not First_Switch then
kono
parents:
diff changeset
766 Osint.Fail
kono
parents:
diff changeset
767 ("-gnatet must not be combined with other switches");
kono
parents:
diff changeset
768 end if;
kono
parents:
diff changeset
769
kono
parents:
diff changeset
770 -- Check for '='
kono
parents:
diff changeset
771
kono
parents:
diff changeset
772 Ptr := Ptr + 1;
kono
parents:
diff changeset
773
kono
parents:
diff changeset
774 if Ptr >= Max or else Switch_Chars (Ptr) /= '=' then
kono
parents:
diff changeset
775 Bad_Switch ("-gnatet");
kono
parents:
diff changeset
776 else
kono
parents:
diff changeset
777 Target_Dependent_Info_Write_Name :=
kono
parents:
diff changeset
778 new String'(Switch_Chars (Ptr + 1 .. Max));
kono
parents:
diff changeset
779 end if;
kono
parents:
diff changeset
780
kono
parents:
diff changeset
781 return;
kono
parents:
diff changeset
782
kono
parents:
diff changeset
783 -- -gnateT (read target dependent information)
kono
parents:
diff changeset
784
kono
parents:
diff changeset
785 when 'T' =>
kono
parents:
diff changeset
786 if not First_Switch then
kono
parents:
diff changeset
787 Osint.Fail
kono
parents:
diff changeset
788 ("-gnateT must not be combined with other switches");
kono
parents:
diff changeset
789 end if;
kono
parents:
diff changeset
790
kono
parents:
diff changeset
791 -- Check for '='
kono
parents:
diff changeset
792
kono
parents:
diff changeset
793 Ptr := Ptr + 1;
kono
parents:
diff changeset
794
kono
parents:
diff changeset
795 if Ptr >= Max or else Switch_Chars (Ptr) /= '=' then
kono
parents:
diff changeset
796 Bad_Switch ("-gnateT");
kono
parents:
diff changeset
797 else
kono
parents:
diff changeset
798 -- This parameter was stored by Set_Targ earlier
kono
parents:
diff changeset
799
kono
parents:
diff changeset
800 pragma Assert
kono
parents:
diff changeset
801 (Target_Dependent_Info_Read_Name.all =
kono
parents:
diff changeset
802 Switch_Chars (Ptr + 1 .. Max));
kono
parents:
diff changeset
803 null;
kono
parents:
diff changeset
804 end if;
kono
parents:
diff changeset
805
kono
parents:
diff changeset
806 return;
kono
parents:
diff changeset
807
kono
parents:
diff changeset
808 -- -gnateu (unrecognized y,V,w switches)
kono
parents:
diff changeset
809
kono
parents:
diff changeset
810 when 'u' =>
kono
parents:
diff changeset
811 Ptr := Ptr + 1;
kono
parents:
diff changeset
812 Ignore_Unrecognized_VWY_Switches := True;
kono
parents:
diff changeset
813
kono
parents:
diff changeset
814 -- -gnateV (validity checks on parameters)
kono
parents:
diff changeset
815
kono
parents:
diff changeset
816 when 'V' =>
kono
parents:
diff changeset
817 Ptr := Ptr + 1;
kono
parents:
diff changeset
818 Check_Validity_Of_Parameters := True;
kono
parents:
diff changeset
819
kono
parents:
diff changeset
820 -- -gnateY (ignore Style_Checks pragmas)
kono
parents:
diff changeset
821
kono
parents:
diff changeset
822 when 'Y' =>
kono
parents:
diff changeset
823 Ignore_Style_Checks_Pragmas := True;
kono
parents:
diff changeset
824 Ptr := Ptr + 1;
kono
parents:
diff changeset
825
kono
parents:
diff changeset
826 -- -gnatez (final delimiter of explicit switches)
kono
parents:
diff changeset
827
kono
parents:
diff changeset
828 -- This is an internal switch
kono
parents:
diff changeset
829
kono
parents:
diff changeset
830 -- All switches that come after -gnatez have been added by
kono
parents:
diff changeset
831 -- the GCC driver and are not stored in the ALI file. See
kono
parents:
diff changeset
832 -- also -gnatea above.
kono
parents:
diff changeset
833
kono
parents:
diff changeset
834 when 'z' =>
kono
parents:
diff changeset
835 Store_Switch := False;
kono
parents:
diff changeset
836 Disable_Switch_Storing;
kono
parents:
diff changeset
837 Ptr := Ptr + 1;
kono
parents:
diff changeset
838
kono
parents:
diff changeset
839 -- All other -gnate? switches are unassigned
kono
parents:
diff changeset
840
kono
parents:
diff changeset
841 when others =>
kono
parents:
diff changeset
842 Bad_Switch ("-gnate" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
843 end case;
kono
parents:
diff changeset
844
kono
parents:
diff changeset
845 -- -gnatE (dynamic elaboration checks)
kono
parents:
diff changeset
846
kono
parents:
diff changeset
847 when 'E' =>
kono
parents:
diff changeset
848 Ptr := Ptr + 1;
kono
parents:
diff changeset
849 Dynamic_Elaboration_Checks := True;
kono
parents:
diff changeset
850
kono
parents:
diff changeset
851 -- -gnatf (full error messages)
kono
parents:
diff changeset
852
kono
parents:
diff changeset
853 when 'f' =>
kono
parents:
diff changeset
854 Ptr := Ptr + 1;
kono
parents:
diff changeset
855 All_Errors_Mode := True;
kono
parents:
diff changeset
856
kono
parents:
diff changeset
857 -- -gnatF (overflow of predefined float types)
kono
parents:
diff changeset
858
kono
parents:
diff changeset
859 when 'F' =>
kono
parents:
diff changeset
860 Ptr := Ptr + 1;
kono
parents:
diff changeset
861 External_Name_Exp_Casing := Uppercase;
kono
parents:
diff changeset
862 External_Name_Imp_Casing := Uppercase;
kono
parents:
diff changeset
863
kono
parents:
diff changeset
864 -- -gnatg (GNAT implementation mode)
kono
parents:
diff changeset
865
kono
parents:
diff changeset
866 when 'g' =>
kono
parents:
diff changeset
867 Ptr := Ptr + 1;
kono
parents:
diff changeset
868 GNAT_Mode := True;
kono
parents:
diff changeset
869 GNAT_Mode_Config := True;
kono
parents:
diff changeset
870 Identifier_Character_Set := 'n';
kono
parents:
diff changeset
871 System_Extend_Unit := Empty;
kono
parents:
diff changeset
872 Warning_Mode := Treat_As_Error;
kono
parents:
diff changeset
873 Style_Check_Main := True;
kono
parents:
diff changeset
874 Ada_Version := Ada_2012;
kono
parents:
diff changeset
875 Ada_Version_Explicit := Ada_2012;
kono
parents:
diff changeset
876 Ada_Version_Pragma := Empty;
kono
parents:
diff changeset
877
kono
parents:
diff changeset
878 -- Set default warnings and style checks for -gnatg
kono
parents:
diff changeset
879
kono
parents:
diff changeset
880 Set_GNAT_Mode_Warnings;
kono
parents:
diff changeset
881 Set_GNAT_Style_Check_Options;
kono
parents:
diff changeset
882
kono
parents:
diff changeset
883 -- -gnatG (output generated code)
kono
parents:
diff changeset
884
kono
parents:
diff changeset
885 when 'G' =>
kono
parents:
diff changeset
886 Ptr := Ptr + 1;
kono
parents:
diff changeset
887 Print_Generated_Code := True;
kono
parents:
diff changeset
888
kono
parents:
diff changeset
889 -- Scan optional integer line limit value
kono
parents:
diff changeset
890
kono
parents:
diff changeset
891 if Nat_Present (Switch_Chars, Max, Ptr) then
kono
parents:
diff changeset
892 Scan_Nat (Switch_Chars, Max, Ptr, Sprint_Line_Limit, 'G');
kono
parents:
diff changeset
893 Sprint_Line_Limit := Nat'Max (Sprint_Line_Limit, 40);
kono
parents:
diff changeset
894 end if;
kono
parents:
diff changeset
895
kono
parents:
diff changeset
896 -- -gnath (help information)
kono
parents:
diff changeset
897
kono
parents:
diff changeset
898 when 'h' =>
kono
parents:
diff changeset
899 Ptr := Ptr + 1;
kono
parents:
diff changeset
900 Usage_Requested := True;
kono
parents:
diff changeset
901
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
902 -- -gnatH (legacy static elaboration checking mode enabled)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
903
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
904 when 'H' =>
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
905 Ptr := Ptr + 1;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
906 Legacy_Elaboration_Checks := True;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
907
111
kono
parents:
diff changeset
908 -- -gnati (character set)
kono
parents:
diff changeset
909
kono
parents:
diff changeset
910 when 'i' =>
kono
parents:
diff changeset
911 if Ptr = Max then
kono
parents:
diff changeset
912 Bad_Switch ("-gnati");
kono
parents:
diff changeset
913 end if;
kono
parents:
diff changeset
914
kono
parents:
diff changeset
915 Ptr := Ptr + 1;
kono
parents:
diff changeset
916 C := Switch_Chars (Ptr);
kono
parents:
diff changeset
917
kono
parents:
diff changeset
918 if C in '1' .. '5'
kono
parents:
diff changeset
919 or else C = '8'
kono
parents:
diff changeset
920 or else C = '9'
kono
parents:
diff changeset
921 or else C = 'p'
kono
parents:
diff changeset
922 or else C = 'f'
kono
parents:
diff changeset
923 or else C = 'n'
kono
parents:
diff changeset
924 or else C = 'w'
kono
parents:
diff changeset
925 then
kono
parents:
diff changeset
926 Identifier_Character_Set := C;
kono
parents:
diff changeset
927 Ptr := Ptr + 1;
kono
parents:
diff changeset
928
kono
parents:
diff changeset
929 else
kono
parents:
diff changeset
930 Bad_Switch ("-gnati" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
931 end if;
kono
parents:
diff changeset
932
kono
parents:
diff changeset
933 -- -gnatI (ignore representation clauses)
kono
parents:
diff changeset
934
kono
parents:
diff changeset
935 when 'I' =>
kono
parents:
diff changeset
936 Ptr := Ptr + 1;
kono
parents:
diff changeset
937 Ignore_Rep_Clauses := True;
kono
parents:
diff changeset
938
kono
parents:
diff changeset
939 -- -gnatj (messages in limited length lines)
kono
parents:
diff changeset
940
kono
parents:
diff changeset
941 when 'j' =>
kono
parents:
diff changeset
942 Ptr := Ptr + 1;
kono
parents:
diff changeset
943 Scan_Nat (Switch_Chars, Max, Ptr, Error_Msg_Line_Length, C);
kono
parents:
diff changeset
944
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
945 -- -gnatJ (relaxed elaboration checking mode enabled)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
946
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
947 when 'J' =>
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
948 Ptr := Ptr + 1;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
949 Relaxed_Elaboration_Checks := True;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
950
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
951 -- Common relaxations for both ABE mechanisms
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
952 --
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
953 -- -gnatd.G (ignore calls through generic formal parameters
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
954 -- for elaboration)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
955 -- -gnatd.U (ignore indirect calls for static elaboration)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
956 -- -gnatd.y (disable implicit pragma Elaborate_All on task
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
957 -- bodies)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
958
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
959 Debug_Flag_Dot_GG := True;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
960 Debug_Flag_Dot_UU := True;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
961 Debug_Flag_Dot_Y := True;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
962
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
963 -- Relaxatons to the legacy ABE mechanism
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
964
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
965 if Legacy_Elaboration_Checks then
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
966 null;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
967
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
968 -- Relaxations to the default ABE mechanism
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
969 --
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
970 -- -gnatd_a (stop elaboration checks on accept or select
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
971 -- statement)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
972 -- -gnatd_e (ignore entry calls and requeue statements for
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
973 -- elaboration)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
974 -- -gnatd_i (ignore activations and calls to instances for
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
975 -- elaboration)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
976 -- -gnatd_p (ignore assertion pragmas for elaboration)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
977 -- -gnatd_s (stop elaboration checks on synchronous
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
978 -- suspension)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
979 -- -gnatdL (ignore external calls from instances for
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
980 -- elaboration)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
981
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
982 else
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
983 Debug_Flag_Underscore_A := True;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
984 Debug_Flag_Underscore_E := True;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
985 Debug_Flag_Underscore_I := True;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
986 Debug_Flag_Underscore_P := True;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
987 Debug_Flag_Underscore_S := True;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
988 Debug_Flag_LL := True;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
989 end if;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
990
111
kono
parents:
diff changeset
991 -- -gnatk (limit file name length)
kono
parents:
diff changeset
992
kono
parents:
diff changeset
993 when 'k' =>
kono
parents:
diff changeset
994 Ptr := Ptr + 1;
kono
parents:
diff changeset
995 Scan_Pos
kono
parents:
diff changeset
996 (Switch_Chars, Max, Ptr, Maximum_File_Name_Length, C);
kono
parents:
diff changeset
997
kono
parents:
diff changeset
998 -- -gnatl (output full source)
kono
parents:
diff changeset
999
kono
parents:
diff changeset
1000 when 'l' =>
kono
parents:
diff changeset
1001 Ptr := Ptr + 1;
kono
parents:
diff changeset
1002 Full_List := True;
kono
parents:
diff changeset
1003
kono
parents:
diff changeset
1004 -- There may be an equal sign between -gnatl and a file name
kono
parents:
diff changeset
1005
kono
parents:
diff changeset
1006 if Ptr <= Max and then Switch_Chars (Ptr) = '=' then
kono
parents:
diff changeset
1007 if Ptr = Max then
kono
parents:
diff changeset
1008 Osint.Fail ("file name for -gnatl= is null");
kono
parents:
diff changeset
1009 else
kono
parents:
diff changeset
1010 Opt.Full_List_File_Name :=
kono
parents:
diff changeset
1011 new String'(Switch_Chars (Ptr + 1 .. Max));
kono
parents:
diff changeset
1012 Ptr := Max + 1;
kono
parents:
diff changeset
1013 end if;
kono
parents:
diff changeset
1014 end if;
kono
parents:
diff changeset
1015
kono
parents:
diff changeset
1016 -- -gnatL (corresponding source text)
kono
parents:
diff changeset
1017
kono
parents:
diff changeset
1018 when 'L' =>
kono
parents:
diff changeset
1019 Ptr := Ptr + 1;
kono
parents:
diff changeset
1020 Dump_Source_Text := True;
kono
parents:
diff changeset
1021
kono
parents:
diff changeset
1022 -- -gnatm (max number or errors/warnings)
kono
parents:
diff changeset
1023
kono
parents:
diff changeset
1024 when 'm' =>
kono
parents:
diff changeset
1025 Ptr := Ptr + 1;
kono
parents:
diff changeset
1026 Scan_Nat (Switch_Chars, Max, Ptr, Maximum_Messages, C);
kono
parents:
diff changeset
1027
kono
parents:
diff changeset
1028 -- -gnatn (enable pragma Inline)
kono
parents:
diff changeset
1029
kono
parents:
diff changeset
1030 when 'n' =>
kono
parents:
diff changeset
1031 Ptr := Ptr + 1;
kono
parents:
diff changeset
1032 Inline_Active := True;
kono
parents:
diff changeset
1033
kono
parents:
diff changeset
1034 -- There may be a digit (1 or 2) appended to the switch
kono
parents:
diff changeset
1035
kono
parents:
diff changeset
1036 if Ptr <= Max then
kono
parents:
diff changeset
1037 C := Switch_Chars (Ptr);
kono
parents:
diff changeset
1038
kono
parents:
diff changeset
1039 if C in '1' .. '2' then
kono
parents:
diff changeset
1040 Ptr := Ptr + 1;
kono
parents:
diff changeset
1041 Inline_Level := Character'Pos (C) - Character'Pos ('0');
kono
parents:
diff changeset
1042 end if;
kono
parents:
diff changeset
1043 end if;
kono
parents:
diff changeset
1044
kono
parents:
diff changeset
1045 -- -gnatN (obsolescent)
kono
parents:
diff changeset
1046
kono
parents:
diff changeset
1047 when 'N' =>
kono
parents:
diff changeset
1048 Ptr := Ptr + 1;
kono
parents:
diff changeset
1049 Inline_Active := True;
kono
parents:
diff changeset
1050 Front_End_Inlining := True;
kono
parents:
diff changeset
1051
kono
parents:
diff changeset
1052 -- -gnato (overflow checks)
kono
parents:
diff changeset
1053
kono
parents:
diff changeset
1054 when 'o' =>
kono
parents:
diff changeset
1055 Ptr := Ptr + 1;
kono
parents:
diff changeset
1056
kono
parents:
diff changeset
1057 -- Case of -gnato0 (overflow checking turned off)
kono
parents:
diff changeset
1058
kono
parents:
diff changeset
1059 if Ptr <= Max and then Switch_Chars (Ptr) = '0' then
kono
parents:
diff changeset
1060 Ptr := Ptr + 1;
kono
parents:
diff changeset
1061 Suppress_Options.Suppress (Overflow_Check) := True;
kono
parents:
diff changeset
1062
kono
parents:
diff changeset
1063 -- We set strict mode in case overflow checking is turned
kono
parents:
diff changeset
1064 -- on locally (also records that we had a -gnato switch).
kono
parents:
diff changeset
1065
kono
parents:
diff changeset
1066 Suppress_Options.Overflow_Mode_General := Strict;
kono
parents:
diff changeset
1067 Suppress_Options.Overflow_Mode_Assertions := Strict;
kono
parents:
diff changeset
1068
kono
parents:
diff changeset
1069 -- All cases other than -gnato0 (overflow checking turned on)
kono
parents:
diff changeset
1070
kono
parents:
diff changeset
1071 else
kono
parents:
diff changeset
1072 Suppress_Options.Suppress (Overflow_Check) := False;
kono
parents:
diff changeset
1073
kono
parents:
diff changeset
1074 -- Case of no digits after the -gnato
kono
parents:
diff changeset
1075
kono
parents:
diff changeset
1076 if Ptr > Max
kono
parents:
diff changeset
1077 or else Switch_Chars (Ptr) not in '1' .. '3'
kono
parents:
diff changeset
1078 then
kono
parents:
diff changeset
1079 Suppress_Options.Overflow_Mode_General := Strict;
kono
parents:
diff changeset
1080 Suppress_Options.Overflow_Mode_Assertions := Strict;
kono
parents:
diff changeset
1081
kono
parents:
diff changeset
1082 -- At least one digit after the -gnato
kono
parents:
diff changeset
1083
kono
parents:
diff changeset
1084 else
kono
parents:
diff changeset
1085 -- Handle first digit after -gnato
kono
parents:
diff changeset
1086
kono
parents:
diff changeset
1087 Suppress_Options.Overflow_Mode_General :=
kono
parents:
diff changeset
1088 Get_Overflow_Mode (Switch_Chars (Ptr));
kono
parents:
diff changeset
1089 Ptr := Ptr + 1;
kono
parents:
diff changeset
1090
kono
parents:
diff changeset
1091 -- Only one digit after -gnato, set assertions mode to be
kono
parents:
diff changeset
1092 -- the same as general mode.
kono
parents:
diff changeset
1093
kono
parents:
diff changeset
1094 if Ptr > Max
kono
parents:
diff changeset
1095 or else Switch_Chars (Ptr) not in '1' .. '3'
kono
parents:
diff changeset
1096 then
kono
parents:
diff changeset
1097 Suppress_Options.Overflow_Mode_Assertions :=
kono
parents:
diff changeset
1098 Suppress_Options.Overflow_Mode_General;
kono
parents:
diff changeset
1099
kono
parents:
diff changeset
1100 -- Process second digit after -gnato
kono
parents:
diff changeset
1101
kono
parents:
diff changeset
1102 else
kono
parents:
diff changeset
1103 Suppress_Options.Overflow_Mode_Assertions :=
kono
parents:
diff changeset
1104 Get_Overflow_Mode (Switch_Chars (Ptr));
kono
parents:
diff changeset
1105 Ptr := Ptr + 1;
kono
parents:
diff changeset
1106 end if;
kono
parents:
diff changeset
1107 end if;
kono
parents:
diff changeset
1108 end if;
kono
parents:
diff changeset
1109
kono
parents:
diff changeset
1110 -- -gnatO (specify name of the object file)
kono
parents:
diff changeset
1111
kono
parents:
diff changeset
1112 -- This is an internal switch
kono
parents:
diff changeset
1113
kono
parents:
diff changeset
1114 when 'O' =>
kono
parents:
diff changeset
1115 Store_Switch := False;
kono
parents:
diff changeset
1116 Ptr := Ptr + 1;
kono
parents:
diff changeset
1117 Output_File_Name_Present := True;
kono
parents:
diff changeset
1118
kono
parents:
diff changeset
1119 -- -gnatp (suppress all checks)
kono
parents:
diff changeset
1120
kono
parents:
diff changeset
1121 when 'p' =>
kono
parents:
diff changeset
1122 Ptr := Ptr + 1;
kono
parents:
diff changeset
1123
kono
parents:
diff changeset
1124 -- Skip processing if cancelled by subsequent -gnat-p
kono
parents:
diff changeset
1125
kono
parents:
diff changeset
1126 if Switch_Subsequently_Cancelled ("p", Args, Arg_Rank) then
kono
parents:
diff changeset
1127 Store_Switch := False;
kono
parents:
diff changeset
1128
kono
parents:
diff changeset
1129 else
kono
parents:
diff changeset
1130 -- Set all specific options as well as All_Checks in the
kono
parents:
diff changeset
1131 -- Suppress_Options array, excluding Elaboration_Check,
kono
parents:
diff changeset
1132 -- since this is treated specially because we do not want
kono
parents:
diff changeset
1133 -- -gnatp to disable static elaboration processing. Also
kono
parents:
diff changeset
1134 -- exclude Atomic_Synchronization, since this is not a real
kono
parents:
diff changeset
1135 -- check.
kono
parents:
diff changeset
1136
kono
parents:
diff changeset
1137 for J in Suppress_Options.Suppress'Range loop
kono
parents:
diff changeset
1138 if J /= Elaboration_Check
kono
parents:
diff changeset
1139 and then
kono
parents:
diff changeset
1140 J /= Atomic_Synchronization
kono
parents:
diff changeset
1141 then
kono
parents:
diff changeset
1142 Suppress_Options.Suppress (J) := True;
kono
parents:
diff changeset
1143 end if;
kono
parents:
diff changeset
1144 end loop;
kono
parents:
diff changeset
1145
kono
parents:
diff changeset
1146 Validity_Checks_On := False;
kono
parents:
diff changeset
1147 Opt.Suppress_Checks := True;
kono
parents:
diff changeset
1148
kono
parents:
diff changeset
1149 -- Set overflow mode checking to strict in case it gets
kono
parents:
diff changeset
1150 -- turned on locally (also signals that overflow checking
kono
parents:
diff changeset
1151 -- has been specifically turned off).
kono
parents:
diff changeset
1152
kono
parents:
diff changeset
1153 Suppress_Options.Overflow_Mode_General := Strict;
kono
parents:
diff changeset
1154 Suppress_Options.Overflow_Mode_Assertions := Strict;
kono
parents:
diff changeset
1155 end if;
kono
parents:
diff changeset
1156
kono
parents:
diff changeset
1157 -- -gnatP (periodic poll)
kono
parents:
diff changeset
1158
kono
parents:
diff changeset
1159 when 'P' =>
kono
parents:
diff changeset
1160 Ptr := Ptr + 1;
kono
parents:
diff changeset
1161 Polling_Required := True;
kono
parents:
diff changeset
1162
kono
parents:
diff changeset
1163 -- -gnatq (don't quit)
kono
parents:
diff changeset
1164
kono
parents:
diff changeset
1165 when 'q' =>
kono
parents:
diff changeset
1166 Ptr := Ptr + 1;
kono
parents:
diff changeset
1167 Try_Semantics := True;
kono
parents:
diff changeset
1168
kono
parents:
diff changeset
1169 -- -gnatQ (always write ALI file)
kono
parents:
diff changeset
1170
kono
parents:
diff changeset
1171 when 'Q' =>
kono
parents:
diff changeset
1172 Ptr := Ptr + 1;
kono
parents:
diff changeset
1173 Force_ALI_Tree_File := True;
kono
parents:
diff changeset
1174 Try_Semantics := True;
kono
parents:
diff changeset
1175
kono
parents:
diff changeset
1176 -- -gnatr (restrictions as warnings)
kono
parents:
diff changeset
1177
kono
parents:
diff changeset
1178 when 'r' =>
kono
parents:
diff changeset
1179 Ptr := Ptr + 1;
kono
parents:
diff changeset
1180 Treat_Restrictions_As_Warnings := True;
kono
parents:
diff changeset
1181
kono
parents:
diff changeset
1182 -- -gnatR (list rep. info)
kono
parents:
diff changeset
1183
kono
parents:
diff changeset
1184 when 'R' =>
kono
parents:
diff changeset
1185
kono
parents:
diff changeset
1186 -- Not allowed if previous -gnatD given. See more extensive
kono
parents:
diff changeset
1187 -- comments in the 'D' section for the inverse test.
kono
parents:
diff changeset
1188
kono
parents:
diff changeset
1189 if Debug_Generated_Code then
kono
parents:
diff changeset
1190 Osint.Fail
kono
parents:
diff changeset
1191 ("-gnatR not permitted since -gnatD given previously");
kono
parents:
diff changeset
1192 end if;
kono
parents:
diff changeset
1193
kono
parents:
diff changeset
1194 -- Set to annotate rep info, and set default -gnatR mode
kono
parents:
diff changeset
1195
kono
parents:
diff changeset
1196 Back_Annotate_Rep_Info := True;
kono
parents:
diff changeset
1197 List_Representation_Info := 1;
kono
parents:
diff changeset
1198
kono
parents:
diff changeset
1199 -- Scan possible parameter
kono
parents:
diff changeset
1200
kono
parents:
diff changeset
1201 Ptr := Ptr + 1;
kono
parents:
diff changeset
1202 while Ptr <= Max loop
kono
parents:
diff changeset
1203 C := Switch_Chars (Ptr);
kono
parents:
diff changeset
1204
kono
parents:
diff changeset
1205 case C is
kono
parents:
diff changeset
1206
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1207 when '0' .. '4' =>
111
kono
parents:
diff changeset
1208 List_Representation_Info :=
kono
parents:
diff changeset
1209 Character'Pos (C) - Character'Pos ('0');
kono
parents:
diff changeset
1210
kono
parents:
diff changeset
1211 when 's' =>
kono
parents:
diff changeset
1212 List_Representation_Info_To_File := True;
kono
parents:
diff changeset
1213
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1214 when 'j' =>
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1215 List_Representation_Info_To_JSON := True;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1216
111
kono
parents:
diff changeset
1217 when 'm' =>
kono
parents:
diff changeset
1218 List_Representation_Info_Mechanisms := True;
kono
parents:
diff changeset
1219
kono
parents:
diff changeset
1220 when 'e' =>
kono
parents:
diff changeset
1221 List_Representation_Info_Extended := True;
kono
parents:
diff changeset
1222
kono
parents:
diff changeset
1223 when others =>
kono
parents:
diff changeset
1224 Bad_Switch ("-gnatR" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
1225 end case;
kono
parents:
diff changeset
1226
kono
parents:
diff changeset
1227 Ptr := Ptr + 1;
kono
parents:
diff changeset
1228 end loop;
kono
parents:
diff changeset
1229
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1230 if List_Representation_Info_To_JSON
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1231 and then List_Representation_Info_Extended
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1232 then
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1233 Osint.Fail ("-gnatRe is incompatible with -gnatRj");
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1234 end if;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1235
111
kono
parents:
diff changeset
1236 -- -gnats (syntax check only)
kono
parents:
diff changeset
1237
kono
parents:
diff changeset
1238 when 's' =>
kono
parents:
diff changeset
1239 if not First_Switch then
kono
parents:
diff changeset
1240 Osint.Fail
kono
parents:
diff changeset
1241 ("-gnats must be first if combined with other switches");
kono
parents:
diff changeset
1242 end if;
kono
parents:
diff changeset
1243
kono
parents:
diff changeset
1244 Ptr := Ptr + 1;
kono
parents:
diff changeset
1245 Operating_Mode := Check_Syntax;
kono
parents:
diff changeset
1246
kono
parents:
diff changeset
1247 -- -gnatS (print package Standard)
kono
parents:
diff changeset
1248
kono
parents:
diff changeset
1249 when 'S' =>
kono
parents:
diff changeset
1250 Print_Standard := True;
kono
parents:
diff changeset
1251 Ptr := Ptr + 1;
kono
parents:
diff changeset
1252
kono
parents:
diff changeset
1253 -- -gnatt (output tree)
kono
parents:
diff changeset
1254
kono
parents:
diff changeset
1255 when 't' =>
kono
parents:
diff changeset
1256 Ptr := Ptr + 1;
kono
parents:
diff changeset
1257 Tree_Output := True;
kono
parents:
diff changeset
1258 Back_Annotate_Rep_Info := True;
kono
parents:
diff changeset
1259
kono
parents:
diff changeset
1260 -- -gnatT (change start of internal table sizes)
kono
parents:
diff changeset
1261
kono
parents:
diff changeset
1262 when 'T' =>
kono
parents:
diff changeset
1263 Ptr := Ptr + 1;
kono
parents:
diff changeset
1264 Scan_Pos (Switch_Chars, Max, Ptr, Table_Factor, C);
kono
parents:
diff changeset
1265
kono
parents:
diff changeset
1266 -- -gnatu (list units for compilation)
kono
parents:
diff changeset
1267
kono
parents:
diff changeset
1268 when 'u' =>
kono
parents:
diff changeset
1269 Ptr := Ptr + 1;
kono
parents:
diff changeset
1270 List_Units := True;
kono
parents:
diff changeset
1271
kono
parents:
diff changeset
1272 -- -gnatU (unique tags)
kono
parents:
diff changeset
1273
kono
parents:
diff changeset
1274 when 'U' =>
kono
parents:
diff changeset
1275 Ptr := Ptr + 1;
kono
parents:
diff changeset
1276 Unique_Error_Tag := True;
kono
parents:
diff changeset
1277
kono
parents:
diff changeset
1278 -- -gnatv (verbose mode)
kono
parents:
diff changeset
1279
kono
parents:
diff changeset
1280 when 'v' =>
kono
parents:
diff changeset
1281 Ptr := Ptr + 1;
kono
parents:
diff changeset
1282 Verbose_Mode := True;
kono
parents:
diff changeset
1283
kono
parents:
diff changeset
1284 -- -gnatV (validity checks)
kono
parents:
diff changeset
1285
kono
parents:
diff changeset
1286 when 'V' =>
kono
parents:
diff changeset
1287 Store_Switch := False;
kono
parents:
diff changeset
1288 Ptr := Ptr + 1;
kono
parents:
diff changeset
1289
kono
parents:
diff changeset
1290 if Ptr > Max then
kono
parents:
diff changeset
1291 Bad_Switch ("-gnatV");
kono
parents:
diff changeset
1292
kono
parents:
diff changeset
1293 else
kono
parents:
diff changeset
1294 declare
kono
parents:
diff changeset
1295 OK : Boolean;
kono
parents:
diff changeset
1296
kono
parents:
diff changeset
1297 begin
kono
parents:
diff changeset
1298 Set_Validity_Check_Options
kono
parents:
diff changeset
1299 (Switch_Chars (Ptr .. Max), OK, Ptr);
kono
parents:
diff changeset
1300
kono
parents:
diff changeset
1301 if not OK then
kono
parents:
diff changeset
1302 Bad_Switch ("-gnatV" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
1303 end if;
kono
parents:
diff changeset
1304
kono
parents:
diff changeset
1305 for Index in First_Char + 1 .. Max loop
kono
parents:
diff changeset
1306 Store_Compilation_Switch
kono
parents:
diff changeset
1307 ("-gnatV" & Switch_Chars (Index));
kono
parents:
diff changeset
1308 end loop;
kono
parents:
diff changeset
1309 end;
kono
parents:
diff changeset
1310 end if;
kono
parents:
diff changeset
1311
kono
parents:
diff changeset
1312 Ptr := Max + 1;
kono
parents:
diff changeset
1313
kono
parents:
diff changeset
1314 -- -gnatw (warning modes)
kono
parents:
diff changeset
1315
kono
parents:
diff changeset
1316 when 'w' =>
kono
parents:
diff changeset
1317 Store_Switch := False;
kono
parents:
diff changeset
1318 Ptr := Ptr + 1;
kono
parents:
diff changeset
1319
kono
parents:
diff changeset
1320 if Ptr > Max then
kono
parents:
diff changeset
1321 Bad_Switch ("-gnatw");
kono
parents:
diff changeset
1322 end if;
kono
parents:
diff changeset
1323
kono
parents:
diff changeset
1324 while Ptr <= Max loop
kono
parents:
diff changeset
1325 C := Switch_Chars (Ptr);
kono
parents:
diff changeset
1326
kono
parents:
diff changeset
1327 -- Case of dot switch
kono
parents:
diff changeset
1328
kono
parents:
diff changeset
1329 if C = '.' and then Ptr < Max then
kono
parents:
diff changeset
1330 Ptr := Ptr + 1;
kono
parents:
diff changeset
1331 C := Switch_Chars (Ptr);
kono
parents:
diff changeset
1332
kono
parents:
diff changeset
1333 if Set_Dot_Warning_Switch (C) then
kono
parents:
diff changeset
1334 Store_Compilation_Switch ("-gnatw." & C);
kono
parents:
diff changeset
1335 else
kono
parents:
diff changeset
1336 Bad_Switch ("-gnatw." & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
1337 end if;
kono
parents:
diff changeset
1338
kono
parents:
diff changeset
1339 -- Case of underscore switch
kono
parents:
diff changeset
1340
kono
parents:
diff changeset
1341 elsif C = '_' and then Ptr < Max then
kono
parents:
diff changeset
1342 Ptr := Ptr + 1;
kono
parents:
diff changeset
1343 C := Switch_Chars (Ptr);
kono
parents:
diff changeset
1344
kono
parents:
diff changeset
1345 if Set_Underscore_Warning_Switch (C) then
kono
parents:
diff changeset
1346 Store_Compilation_Switch ("-gnatw_" & C);
kono
parents:
diff changeset
1347 else
kono
parents:
diff changeset
1348 Bad_Switch ("-gnatw_" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
1349 end if;
kono
parents:
diff changeset
1350
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1351 -- Normal case
111
kono
parents:
diff changeset
1352
kono
parents:
diff changeset
1353 else
kono
parents:
diff changeset
1354 if Set_Warning_Switch (C) then
kono
parents:
diff changeset
1355 Store_Compilation_Switch ("-gnatw" & C);
kono
parents:
diff changeset
1356 else
kono
parents:
diff changeset
1357 Bad_Switch ("-gnatw" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
1358 end if;
kono
parents:
diff changeset
1359 end if;
kono
parents:
diff changeset
1360
kono
parents:
diff changeset
1361 Ptr := Ptr + 1;
kono
parents:
diff changeset
1362 end loop;
kono
parents:
diff changeset
1363
kono
parents:
diff changeset
1364 return;
kono
parents:
diff changeset
1365
kono
parents:
diff changeset
1366 -- -gnatW (wide character encoding method)
kono
parents:
diff changeset
1367
kono
parents:
diff changeset
1368 when 'W' =>
kono
parents:
diff changeset
1369 Ptr := Ptr + 1;
kono
parents:
diff changeset
1370
kono
parents:
diff changeset
1371 if Ptr > Max then
kono
parents:
diff changeset
1372 Bad_Switch ("-gnatW");
kono
parents:
diff changeset
1373 end if;
kono
parents:
diff changeset
1374
kono
parents:
diff changeset
1375 begin
kono
parents:
diff changeset
1376 Wide_Character_Encoding_Method :=
kono
parents:
diff changeset
1377 Get_WC_Encoding_Method (Switch_Chars (Ptr));
kono
parents:
diff changeset
1378 exception
kono
parents:
diff changeset
1379 when Constraint_Error =>
kono
parents:
diff changeset
1380 Bad_Switch ("-gnatW" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
1381 end;
kono
parents:
diff changeset
1382
kono
parents:
diff changeset
1383 Wide_Character_Encoding_Method_Specified := True;
kono
parents:
diff changeset
1384
kono
parents:
diff changeset
1385 Upper_Half_Encoding :=
kono
parents:
diff changeset
1386 Wide_Character_Encoding_Method in
kono
parents:
diff changeset
1387 WC_Upper_Half_Encoding_Method;
kono
parents:
diff changeset
1388
kono
parents:
diff changeset
1389 Ptr := Ptr + 1;
kono
parents:
diff changeset
1390
kono
parents:
diff changeset
1391 -- -gnatx (suppress cross-ref information)
kono
parents:
diff changeset
1392
kono
parents:
diff changeset
1393 when 'x' =>
kono
parents:
diff changeset
1394 Ptr := Ptr + 1;
kono
parents:
diff changeset
1395 Xref_Active := False;
kono
parents:
diff changeset
1396
kono
parents:
diff changeset
1397 -- -gnatX (language extensions)
kono
parents:
diff changeset
1398
kono
parents:
diff changeset
1399 when 'X' =>
kono
parents:
diff changeset
1400 Ptr := Ptr + 1;
kono
parents:
diff changeset
1401 Extensions_Allowed := True;
kono
parents:
diff changeset
1402 Ada_Version := Ada_Version_Type'Last;
kono
parents:
diff changeset
1403 Ada_Version_Explicit := Ada_Version_Type'Last;
kono
parents:
diff changeset
1404 Ada_Version_Pragma := Empty;
kono
parents:
diff changeset
1405
kono
parents:
diff changeset
1406 -- -gnaty (style checks)
kono
parents:
diff changeset
1407
kono
parents:
diff changeset
1408 when 'y' =>
kono
parents:
diff changeset
1409 Ptr := Ptr + 1;
kono
parents:
diff changeset
1410 Style_Check_Main := True;
kono
parents:
diff changeset
1411
kono
parents:
diff changeset
1412 if Ptr > Max then
kono
parents:
diff changeset
1413 Set_Default_Style_Check_Options;
kono
parents:
diff changeset
1414
kono
parents:
diff changeset
1415 else
kono
parents:
diff changeset
1416 Store_Switch := False;
kono
parents:
diff changeset
1417
kono
parents:
diff changeset
1418 declare
kono
parents:
diff changeset
1419 OK : Boolean;
kono
parents:
diff changeset
1420
kono
parents:
diff changeset
1421 begin
kono
parents:
diff changeset
1422 Set_Style_Check_Options
kono
parents:
diff changeset
1423 (Switch_Chars (Ptr .. Max), OK, Ptr);
kono
parents:
diff changeset
1424
kono
parents:
diff changeset
1425 if not OK then
kono
parents:
diff changeset
1426 Osint.Fail
kono
parents:
diff changeset
1427 ("bad -gnaty switch (" &
kono
parents:
diff changeset
1428 Style_Msg_Buf (1 .. Style_Msg_Len) & ')');
kono
parents:
diff changeset
1429 end if;
kono
parents:
diff changeset
1430
kono
parents:
diff changeset
1431 Ptr := First_Char + 1;
kono
parents:
diff changeset
1432 while Ptr <= Max loop
kono
parents:
diff changeset
1433 if Switch_Chars (Ptr) = 'M' then
kono
parents:
diff changeset
1434 First_Char := Ptr;
kono
parents:
diff changeset
1435 loop
kono
parents:
diff changeset
1436 Ptr := Ptr + 1;
kono
parents:
diff changeset
1437 exit when Ptr > Max
kono
parents:
diff changeset
1438 or else Switch_Chars (Ptr) not in '0' .. '9';
kono
parents:
diff changeset
1439 end loop;
kono
parents:
diff changeset
1440
kono
parents:
diff changeset
1441 Store_Compilation_Switch
kono
parents:
diff changeset
1442 ("-gnaty" & Switch_Chars (First_Char .. Ptr - 1));
kono
parents:
diff changeset
1443
kono
parents:
diff changeset
1444 else
kono
parents:
diff changeset
1445 Store_Compilation_Switch
kono
parents:
diff changeset
1446 ("-gnaty" & Switch_Chars (Ptr));
kono
parents:
diff changeset
1447 Ptr := Ptr + 1;
kono
parents:
diff changeset
1448 end if;
kono
parents:
diff changeset
1449 end loop;
kono
parents:
diff changeset
1450 end;
kono
parents:
diff changeset
1451 end if;
kono
parents:
diff changeset
1452
kono
parents:
diff changeset
1453 -- -gnatz (stub generation)
kono
parents:
diff changeset
1454
kono
parents:
diff changeset
1455 when 'z' =>
kono
parents:
diff changeset
1456
kono
parents:
diff changeset
1457 -- -gnatz must be the first and only switch in Switch_Chars,
kono
parents:
diff changeset
1458 -- and is a two-letter switch.
kono
parents:
diff changeset
1459
kono
parents:
diff changeset
1460 if Ptr /= Switch_Chars'First + 5
kono
parents:
diff changeset
1461 or else (Max - Ptr + 1) > 2
kono
parents:
diff changeset
1462 then
kono
parents:
diff changeset
1463 Osint.Fail
kono
parents:
diff changeset
1464 ("-gnatz* may not be combined with other switches");
kono
parents:
diff changeset
1465 end if;
kono
parents:
diff changeset
1466
kono
parents:
diff changeset
1467 if Ptr = Max then
kono
parents:
diff changeset
1468 Bad_Switch ("-gnatz");
kono
parents:
diff changeset
1469 end if;
kono
parents:
diff changeset
1470
kono
parents:
diff changeset
1471 Ptr := Ptr + 1;
kono
parents:
diff changeset
1472
kono
parents:
diff changeset
1473 -- Only one occurrence of -gnat* is permitted
kono
parents:
diff changeset
1474
kono
parents:
diff changeset
1475 if Distribution_Stub_Mode = No_Stubs then
kono
parents:
diff changeset
1476 case Switch_Chars (Ptr) is
kono
parents:
diff changeset
1477 when 'r' =>
kono
parents:
diff changeset
1478 Distribution_Stub_Mode := Generate_Receiver_Stub_Body;
kono
parents:
diff changeset
1479
kono
parents:
diff changeset
1480 when 'c' =>
kono
parents:
diff changeset
1481 Distribution_Stub_Mode := Generate_Caller_Stub_Body;
kono
parents:
diff changeset
1482
kono
parents:
diff changeset
1483 when others =>
kono
parents:
diff changeset
1484 Bad_Switch ("-gnatz" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
1485 end case;
kono
parents:
diff changeset
1486
kono
parents:
diff changeset
1487 Ptr := Ptr + 1;
kono
parents:
diff changeset
1488
kono
parents:
diff changeset
1489 else
kono
parents:
diff changeset
1490 Osint.Fail ("only one -gnatz* switch allowed");
kono
parents:
diff changeset
1491 end if;
kono
parents:
diff changeset
1492
kono
parents:
diff changeset
1493 -- -gnatZ (obsolescent)
kono
parents:
diff changeset
1494
kono
parents:
diff changeset
1495 when 'Z' =>
kono
parents:
diff changeset
1496 Ptr := Ptr + 1;
kono
parents:
diff changeset
1497 Osint.Fail
kono
parents:
diff changeset
1498 ("-gnatZ is no longer supported: consider using --RTS=zcx");
kono
parents:
diff changeset
1499
kono
parents:
diff changeset
1500 -- Note on language version switches: whenever a new language
kono
parents:
diff changeset
1501 -- version switch is added, Switch.M.Normalize_Compiler_Switches
kono
parents:
diff changeset
1502 -- must be updated.
kono
parents:
diff changeset
1503
kono
parents:
diff changeset
1504 -- -gnat83
kono
parents:
diff changeset
1505
kono
parents:
diff changeset
1506 when '8' =>
kono
parents:
diff changeset
1507 if Ptr = Max then
kono
parents:
diff changeset
1508 Bad_Switch ("-gnat8");
kono
parents:
diff changeset
1509 end if;
kono
parents:
diff changeset
1510
kono
parents:
diff changeset
1511 Ptr := Ptr + 1;
kono
parents:
diff changeset
1512
kono
parents:
diff changeset
1513 if Switch_Chars (Ptr) /= '3' or else Latest_Ada_Only then
kono
parents:
diff changeset
1514 Bad_Switch ("-gnat8" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
1515 else
kono
parents:
diff changeset
1516 Ptr := Ptr + 1;
kono
parents:
diff changeset
1517 Ada_Version := Ada_83;
kono
parents:
diff changeset
1518 Ada_Version_Explicit := Ada_83;
kono
parents:
diff changeset
1519 Ada_Version_Pragma := Empty;
kono
parents:
diff changeset
1520 end if;
kono
parents:
diff changeset
1521
kono
parents:
diff changeset
1522 -- -gnat95
kono
parents:
diff changeset
1523
kono
parents:
diff changeset
1524 when '9' =>
kono
parents:
diff changeset
1525 if Ptr = Max then
kono
parents:
diff changeset
1526 Bad_Switch ("-gnat9");
kono
parents:
diff changeset
1527 end if;
kono
parents:
diff changeset
1528
kono
parents:
diff changeset
1529 Ptr := Ptr + 1;
kono
parents:
diff changeset
1530
kono
parents:
diff changeset
1531 if Switch_Chars (Ptr) /= '5' or else Latest_Ada_Only then
kono
parents:
diff changeset
1532 Bad_Switch ("-gnat9" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
1533 else
kono
parents:
diff changeset
1534 Ptr := Ptr + 1;
kono
parents:
diff changeset
1535 Ada_Version := Ada_95;
kono
parents:
diff changeset
1536 Ada_Version_Explicit := Ada_95;
kono
parents:
diff changeset
1537 Ada_Version_Pragma := Empty;
kono
parents:
diff changeset
1538 end if;
kono
parents:
diff changeset
1539
kono
parents:
diff changeset
1540 -- -gnat05
kono
parents:
diff changeset
1541
kono
parents:
diff changeset
1542 when '0' =>
kono
parents:
diff changeset
1543 if Ptr = Max then
kono
parents:
diff changeset
1544 Bad_Switch ("-gnat0");
kono
parents:
diff changeset
1545 end if;
kono
parents:
diff changeset
1546
kono
parents:
diff changeset
1547 Ptr := Ptr + 1;
kono
parents:
diff changeset
1548
kono
parents:
diff changeset
1549 if Switch_Chars (Ptr) /= '5' or else Latest_Ada_Only then
kono
parents:
diff changeset
1550 Bad_Switch ("-gnat0" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
1551 else
kono
parents:
diff changeset
1552 Ptr := Ptr + 1;
kono
parents:
diff changeset
1553 Ada_Version := Ada_2005;
kono
parents:
diff changeset
1554 Ada_Version_Explicit := Ada_2005;
kono
parents:
diff changeset
1555 Ada_Version_Pragma := Empty;
kono
parents:
diff changeset
1556 end if;
kono
parents:
diff changeset
1557
kono
parents:
diff changeset
1558 -- -gnat12
kono
parents:
diff changeset
1559
kono
parents:
diff changeset
1560 when '1' =>
kono
parents:
diff changeset
1561 if Ptr = Max then
kono
parents:
diff changeset
1562 Bad_Switch ("-gnat1");
kono
parents:
diff changeset
1563 end if;
kono
parents:
diff changeset
1564
kono
parents:
diff changeset
1565 Ptr := Ptr + 1;
kono
parents:
diff changeset
1566
kono
parents:
diff changeset
1567 if Switch_Chars (Ptr) /= '2' then
kono
parents:
diff changeset
1568 Bad_Switch ("-gnat1" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
1569 else
kono
parents:
diff changeset
1570 Ptr := Ptr + 1;
kono
parents:
diff changeset
1571 Ada_Version := Ada_2012;
kono
parents:
diff changeset
1572 Ada_Version_Explicit := Ada_2012;
kono
parents:
diff changeset
1573 Ada_Version_Pragma := Empty;
kono
parents:
diff changeset
1574 end if;
kono
parents:
diff changeset
1575
kono
parents:
diff changeset
1576 -- -gnat2005 and -gnat2012
kono
parents:
diff changeset
1577
kono
parents:
diff changeset
1578 when '2' =>
kono
parents:
diff changeset
1579 if Ptr > Max - 3 then
kono
parents:
diff changeset
1580 Bad_Switch ("-gnat" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
1581
kono
parents:
diff changeset
1582 elsif Switch_Chars (Ptr .. Ptr + 3) = "2005"
kono
parents:
diff changeset
1583 and then not Latest_Ada_Only
kono
parents:
diff changeset
1584 then
kono
parents:
diff changeset
1585 Ada_Version := Ada_2005;
kono
parents:
diff changeset
1586
kono
parents:
diff changeset
1587 elsif Switch_Chars (Ptr .. Ptr + 3) = "2012" then
kono
parents:
diff changeset
1588 Ada_Version := Ada_2012;
kono
parents:
diff changeset
1589
kono
parents:
diff changeset
1590 elsif Switch_Chars (Ptr .. Ptr + 3) = "2020" then
kono
parents:
diff changeset
1591 Ada_Version := Ada_2020;
kono
parents:
diff changeset
1592
kono
parents:
diff changeset
1593 else
kono
parents:
diff changeset
1594 Bad_Switch ("-gnat" & Switch_Chars (Ptr .. Ptr + 3));
kono
parents:
diff changeset
1595 end if;
kono
parents:
diff changeset
1596
kono
parents:
diff changeset
1597 Ada_Version_Explicit := Ada_Version;
kono
parents:
diff changeset
1598 Ada_Version_Pragma := Empty;
kono
parents:
diff changeset
1599 Ptr := Ptr + 4;
kono
parents:
diff changeset
1600
kono
parents:
diff changeset
1601 -- Switch cancellation, currently only -gnat-p is allowed.
kono
parents:
diff changeset
1602 -- All we do here is the error checking, since the actual
kono
parents:
diff changeset
1603 -- processing for switch cancellation is done by calls to
kono
parents:
diff changeset
1604 -- Switch_Subsequently_Cancelled at the appropriate point.
kono
parents:
diff changeset
1605
kono
parents:
diff changeset
1606 when '-' =>
kono
parents:
diff changeset
1607
kono
parents:
diff changeset
1608 -- Simple ignore -gnat-p
kono
parents:
diff changeset
1609
kono
parents:
diff changeset
1610 if Switch_Chars = "-gnat-p" then
kono
parents:
diff changeset
1611 return;
kono
parents:
diff changeset
1612
kono
parents:
diff changeset
1613 -- Any other occurrence of minus is ignored. This is for
kono
parents:
diff changeset
1614 -- maximum compatibility with previous version which ignored
kono
parents:
diff changeset
1615 -- all occurrences of minus.
kono
parents:
diff changeset
1616
kono
parents:
diff changeset
1617 else
kono
parents:
diff changeset
1618 Store_Switch := False;
kono
parents:
diff changeset
1619 Ptr := Ptr + 1;
kono
parents:
diff changeset
1620 end if;
kono
parents:
diff changeset
1621
kono
parents:
diff changeset
1622 -- We ignore '/' in switches, this is historical, still needed???
kono
parents:
diff changeset
1623
kono
parents:
diff changeset
1624 when '/' =>
kono
parents:
diff changeset
1625 Store_Switch := False;
kono
parents:
diff changeset
1626
kono
parents:
diff changeset
1627 -- Anything else is an error (illegal switch character)
kono
parents:
diff changeset
1628
kono
parents:
diff changeset
1629 when others =>
kono
parents:
diff changeset
1630 Bad_Switch ("-gnat" & Switch_Chars (Ptr .. Max));
kono
parents:
diff changeset
1631 end case;
kono
parents:
diff changeset
1632
kono
parents:
diff changeset
1633 if Store_Switch then
kono
parents:
diff changeset
1634 Store_Compilation_Switch
kono
parents:
diff changeset
1635 ("-gnat" & Switch_Chars (First_Char .. Ptr - 1));
kono
parents:
diff changeset
1636 end if;
kono
parents:
diff changeset
1637
kono
parents:
diff changeset
1638 First_Switch := False;
kono
parents:
diff changeset
1639 end loop;
kono
parents:
diff changeset
1640 end if;
kono
parents:
diff changeset
1641 end Scan_Front_End_Switches;
kono
parents:
diff changeset
1642
kono
parents:
diff changeset
1643 -----------------------------------
kono
parents:
diff changeset
1644 -- Switch_Subsequently_Cancelled --
kono
parents:
diff changeset
1645 -----------------------------------
kono
parents:
diff changeset
1646
kono
parents:
diff changeset
1647 function Switch_Subsequently_Cancelled
kono
parents:
diff changeset
1648 (C : String;
kono
parents:
diff changeset
1649 Args : String_List;
kono
parents:
diff changeset
1650 Arg_Rank : Positive) return Boolean
kono
parents:
diff changeset
1651 is
kono
parents:
diff changeset
1652 begin
kono
parents:
diff changeset
1653 -- Loop through arguments following the current one
kono
parents:
diff changeset
1654
kono
parents:
diff changeset
1655 for Arg in Arg_Rank + 1 .. Args'Last loop
kono
parents:
diff changeset
1656 if Args (Arg).all = "-gnat-" & C then
kono
parents:
diff changeset
1657 return True;
kono
parents:
diff changeset
1658 end if;
kono
parents:
diff changeset
1659 end loop;
kono
parents:
diff changeset
1660
kono
parents:
diff changeset
1661 -- No match found, not cancelled
kono
parents:
diff changeset
1662
kono
parents:
diff changeset
1663 return False;
kono
parents:
diff changeset
1664 end Switch_Subsequently_Cancelled;
kono
parents:
diff changeset
1665
kono
parents:
diff changeset
1666 end Switch.C;