Branch data Line data Source code
1 : : /* C/ObjC/C++ command line option handling.
2 : : Copyright (C) 2002-2025 Free Software Foundation, Inc.
3 : : Contributed by Neil Booth.
4 : :
5 : : This file is part of GCC.
6 : :
7 : : GCC is free software; you can redistribute it and/or modify it under
8 : : the terms of the GNU General Public License as published by the Free
9 : : Software Foundation; either version 3, or (at your option) any later
10 : : version.
11 : :
12 : : GCC is distributed in the hope that it will be useful, but WITHOUT ANY
13 : : WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 : : FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
15 : : for more details.
16 : :
17 : : You should have received a copy of the GNU General Public License
18 : : along with GCC; see the file COPYING3. If not see
19 : : <http://www.gnu.org/licenses/>. */
20 : :
21 : : #include "config.h"
22 : : #include "system.h"
23 : : #include "coretypes.h"
24 : : #include "tm.h"
25 : : #include "target.h"
26 : : #include "c-target.h"
27 : : #include "c-common.h"
28 : : #include "memmodel.h"
29 : : #include "tm_p.h" /* For C_COMMON_OVERRIDE_OPTIONS. */
30 : : #include "diagnostic.h"
31 : : #include "c-pragma.h"
32 : : #include "flags.h"
33 : : #include "toplev.h"
34 : : #include "langhooks.h"
35 : : #include "diagnostics/macro-unwinding.h" /* for virt_loc_aware_diagnostic_finalizer */
36 : : #include "intl.h"
37 : : #include "cppdefault.h"
38 : : #include "incpath.h"
39 : : #include "debug.h" /* For debug_hooks. */
40 : : #include "opts.h"
41 : : #include "plugin.h" /* For PLUGIN_INCLUDE_FILE event. */
42 : : #include "mkdeps.h"
43 : : #include "dumpfile.h"
44 : : #include "file-prefix-map.h" /* add_*_prefix_map() */
45 : : #include "context.h"
46 : : #include "diagnostics/text-sink.h"
47 : :
48 : : #ifndef DOLLARS_IN_IDENTIFIERS
49 : : # define DOLLARS_IN_IDENTIFIERS true
50 : : #endif
51 : :
52 : : #ifndef TARGET_SYSTEM_ROOT
53 : : # define TARGET_SYSTEM_ROOT NULL
54 : : #endif
55 : :
56 : : #ifndef TARGET_OPTF
57 : : #define TARGET_OPTF(ARG)
58 : : #endif
59 : :
60 : : /* CPP's options. */
61 : : cpp_options *cpp_opts;
62 : :
63 : : /* Input filename. */
64 : : static const char *this_input_filename;
65 : :
66 : : /* Filename and stream for preprocessed output. */
67 : : static const char *out_fname;
68 : : static FILE *out_stream;
69 : :
70 : : /* Append dependencies to deps_file. */
71 : : static bool deps_append;
72 : :
73 : : /* If dependency switches (-MF etc.) have been given. */
74 : : static bool deps_seen;
75 : :
76 : : /* If -v seen. */
77 : : static bool verbose;
78 : :
79 : : /* Dependency output file. */
80 : : static const char *deps_file;
81 : :
82 : : /* Structured dependency output file. */
83 : : static const char *fdeps_file;
84 : :
85 : : /* The prefix given by -iprefix, if any. */
86 : : static const char *iprefix;
87 : :
88 : : /* The multilib directory given by -imultilib, if any. */
89 : : static const char *imultilib;
90 : :
91 : : /* The system root, if any. Overridden by -isysroot. */
92 : : static const char *sysroot = TARGET_SYSTEM_ROOT;
93 : :
94 : : /* Zero disables all standard directories for headers. */
95 : : static bool std_inc = true;
96 : :
97 : : /* Zero disables the C++-specific standard directories for headers. */
98 : : static bool std_cxx_inc = true;
99 : :
100 : : /* If the quote chain has been split by -I-. */
101 : : static bool quote_chain_split;
102 : :
103 : : /* Number of deferred options. */
104 : : static size_t deferred_count;
105 : :
106 : : /* Number of deferred options scanned for -include. */
107 : : static size_t include_cursor;
108 : :
109 : : /* Whether any standard preincluded header has been preincluded. */
110 : : static bool done_preinclude;
111 : :
112 : : static void handle_OPT_d (const char *);
113 : : static void set_std_cxx98 (int);
114 : : static void set_std_cxx11 (int);
115 : : static void set_std_cxx14 (int);
116 : : static void set_std_cxx17 (int);
117 : : static void set_std_cxx20 (int);
118 : : static void set_std_cxx23 (int);
119 : : static void set_std_cxx26 (int);
120 : : static void set_std_c89 (int, int);
121 : : static void set_std_c99 (int);
122 : : static void set_std_c11 (int);
123 : : static void set_std_c17 (int);
124 : : static void set_std_c23 (int);
125 : : static void set_std_c2y (int);
126 : : static void check_deps_environment_vars (void);
127 : : static void handle_deferred_opts (void);
128 : : static void sanitize_cpp_opts (void);
129 : : static void add_prefixed_path (const char *, incpath_kind);
130 : : static void push_command_line_include (void);
131 : : static void cb_file_change (cpp_reader *, const line_map_ordinary *);
132 : : static void cb_dir_change (cpp_reader *, const char *);
133 : : static void c_finish_options (void);
134 : :
135 : : #ifndef STDC_0_IN_SYSTEM_HEADERS
136 : : #define STDC_0_IN_SYSTEM_HEADERS 0
137 : : #endif
138 : :
139 : : /* Holds switches parsed by c_common_handle_option (), but whose
140 : : handling is deferred to c_common_post_options (). */
141 : : static void defer_opt (enum opt_code, const char *);
142 : : static struct deferred_opt
143 : : {
144 : : enum opt_code code;
145 : : const char *arg;
146 : : } *deferred_opts;
147 : :
148 : :
149 : : extern const unsigned int
150 : : c_family_lang_mask = (CL_C | CL_CXX | CL_ObjC | CL_ObjCXX);
151 : :
152 : : /* Defer option CODE with argument ARG. */
153 : : static void
154 : 180811 : defer_opt (enum opt_code code, const char *arg)
155 : : {
156 : 180811 : deferred_opts[deferred_count].code = code;
157 : 180811 : deferred_opts[deferred_count].arg = arg;
158 : 180811 : deferred_count++;
159 : 180811 : }
160 : :
161 : : /* Return language mask for option parsing. */
162 : : unsigned int
163 : 5902976 : c_common_option_lang_mask (void)
164 : : {
165 : 5902976 : static const unsigned int lang_flags[] = {CL_C, CL_ObjC, CL_CXX, CL_ObjCXX};
166 : :
167 : 5902976 : return lang_flags[c_language];
168 : : }
169 : :
170 : : /* Diagnostic finalizer for C/C++/Objective-C/Objective-C++. */
171 : : static void
172 : 303201 : c_diagnostic_text_finalizer (diagnostics::text_sink &text_output,
173 : : const diagnostics::diagnostic_info *diagnostic,
174 : : enum diagnostics::kind)
175 : : {
176 : 303201 : pretty_printer *const pp = text_output.get_printer ();
177 : 303201 : char *saved_prefix = pp_take_prefix (pp);
178 : 303201 : pp_set_prefix (pp, text_output.build_indent_prefix (false));
179 : 303201 : pp_newline (pp);
180 : 303201 : diagnostic_show_locus (&text_output.get_context (),
181 : 303201 : text_output.get_source_printing_options (),
182 : 303201 : diagnostic->m_richloc, diagnostic->m_kind, pp);
183 : : /* By default print macro expansion contexts in the diagnostic
184 : : finalizer -- for tokens resulting from macro expansion. */
185 : 303201 : diagnostics::virt_loc_aware_text_finalizer (text_output, diagnostic);
186 : 303201 : pp_set_prefix (pp, saved_prefix);
187 : 303201 : pp_flush (pp);
188 : 303201 : }
189 : :
190 : : /* Common default settings for diagnostics. */
191 : : void
192 : 203977 : c_common_diagnostics_set_defaults (diagnostics::context *context)
193 : : {
194 : 203977 : diagnostics::text_finalizer (context) = c_diagnostic_text_finalizer;
195 : 203977 : context->set_permissive_option (OPT_fpermissive);
196 : 203977 : }
197 : :
198 : : /* Input charset configuration for diagnostics. */
199 : : static const char *
200 : 60099 : c_common_input_charset_cb (const char * /*filename*/)
201 : : {
202 : 60099 : const char *cs = cpp_opts->input_charset;
203 : 60099 : return cpp_input_conversion_is_trivial (cs) ? nullptr : cs;
204 : : }
205 : :
206 : : /* Whether options from all C-family languages should be accepted
207 : : quietly. */
208 : : static bool accept_all_c_family_options = false;
209 : :
210 : : /* Return whether to complain about a wrong-language option. */
211 : : bool
212 : 292 : c_common_complain_wrong_lang_p (const struct cl_option *option)
213 : : {
214 : 292 : if (accept_all_c_family_options
215 : 6 : && (option->flags & c_family_lang_mask))
216 : 6 : return false;
217 : :
218 : : return true;
219 : : }
220 : :
221 : : /* Initialize options structure OPTS. */
222 : : void
223 : 47227871 : c_common_init_options_struct (struct gcc_options *opts)
224 : : {
225 : 47227871 : opts->x_flag_exceptions = c_dialect_cxx ();
226 : 47227871 : opts->x_warn_pointer_arith = c_dialect_cxx ();
227 : 47227871 : opts->x_warn_write_strings = c_dialect_cxx ();
228 : 47227871 : opts->x_flag_warn_unused_result = true;
229 : :
230 : : /* By default, C99-like requirements for complex multiply and divide. */
231 : 47227871 : opts->x_flag_complex_method = 2;
232 : 47227871 : opts->x_flag_default_complex_method = opts->x_flag_complex_method;
233 : 47227871 : }
234 : :
235 : : /* Common initialization before calling option handlers. */
236 : : void
237 : 203977 : c_common_init_options (unsigned int decoded_options_count,
238 : : struct cl_decoded_option *decoded_options)
239 : : {
240 : 203977 : unsigned int i;
241 : 203977 : struct cpp_callbacks *cb;
242 : :
243 : 203977 : g_string_concat_db
244 : 203977 : = new (ggc_alloc <string_concat_db> ()) string_concat_db ();
245 : :
246 : 311450 : parse_in = cpp_create_reader (c_dialect_cxx () ? CLK_GNUCXX : CLK_GNUC89,
247 : : ident_hash, line_table, ident_hash_extra);
248 : 203977 : cb = cpp_get_callbacks (parse_in);
249 : 203977 : cb->diagnostic = c_cpp_diagnostic;
250 : :
251 : 203977 : cpp_opts = cpp_get_options (parse_in);
252 : 203977 : cpp_opts->dollars_in_ident = DOLLARS_IN_IDENTIFIERS;
253 : 203977 : cpp_opts->objc = c_dialect_objc ();
254 : 203977 : cpp_opts->deps.modules = true;
255 : :
256 : : /* Reset to avoid warnings on internal definitions. We set it just
257 : : before passing on command-line options to cpplib. */
258 : 203977 : cpp_opts->warn_dollars = 0;
259 : :
260 : 203977 : deferred_opts = XNEWVEC (struct deferred_opt, decoded_options_count);
261 : :
262 : 203977 : if (c_language == clk_c)
263 : : {
264 : : /* The default for C is gnu23. */
265 : 107473 : set_std_c23 (false /* ISO */);
266 : :
267 : : /* If preprocessing assembly language, accept any of the C-family
268 : : front end options since the driver may pass them through. */
269 : 2654582 : for (i = 1; i < decoded_options_count; i++)
270 : 2440617 : if (decoded_options[i].opt_index == OPT_lang_asm)
271 : : {
272 : 981 : accept_all_c_family_options = true;
273 : 981 : break;
274 : : }
275 : : }
276 : :
277 : : /* Set C++ standard to C++17 if not specified on the command line. */
278 : 203977 : if (c_dialect_cxx ())
279 : 96504 : set_std_cxx17 (/*ISO*/false);
280 : :
281 : 203977 : global_dc->get_source_printing_options ().colorize_source_p = true;
282 : 203977 : }
283 : :
284 : : /* Handle switch SCODE with argument ARG. VALUE is true, unless no-
285 : : form of an -f or -W option was given. Returns false if the switch was
286 : : invalid, true if valid. Use HANDLERS in recursive handle_option calls. */
287 : : bool
288 : 3284097 : c_common_handle_option (size_t scode, const char *arg, HOST_WIDE_INT value,
289 : : int kind, location_t loc,
290 : : const struct cl_option_handlers *handlers)
291 : : {
292 : 3284097 : const struct cl_option *option = &cl_options[scode];
293 : 3284097 : enum opt_code code = (enum opt_code) scode;
294 : 3284097 : bool result = true;
295 : :
296 : : /* Prevent resetting the language standard to a C dialect when the driver
297 : : has already determined that we're looking at assembler input. */
298 : 3284097 : bool preprocessing_asm_p = (cpp_get_options (parse_in)->lang == CLK_ASM);
299 : :
300 : 3284097 : switch (code)
301 : : {
302 : 1420013 : default:
303 : 1420013 : if (cl_options[code].flags & c_family_lang_mask)
304 : : {
305 : 1420013 : if ((option->flags & CL_TARGET)
306 : 1420013 : && ! targetcm.handle_c_option (scode, arg, value))
307 : : result = false;
308 : : break;
309 : : }
310 : : result = false;
311 : : break;
312 : :
313 : 428 : case OPT__output_pch:
314 : 428 : pch_file = arg;
315 : 428 : break;
316 : :
317 : 10 : case OPT_A:
318 : 10 : defer_opt (code, arg);
319 : 10 : break;
320 : :
321 : 13 : case OPT_C:
322 : 13 : cpp_opts->discard_comments = 0;
323 : 13 : break;
324 : :
325 : 11 : case OPT_CC:
326 : 11 : cpp_opts->discard_comments = 0;
327 : 11 : cpp_opts->discard_comments_in_macro_exp = 0;
328 : 11 : break;
329 : :
330 : 164742 : case OPT_D:
331 : 164742 : defer_opt (code, arg);
332 : 164742 : break;
333 : :
334 : 24 : case OPT_H:
335 : 24 : cpp_opts->print_include_names = 1;
336 : 24 : break;
337 : :
338 : : case OPT_F:
339 : : TARGET_OPTF (xstrdup (arg));
340 : : break;
341 : :
342 : 546473 : case OPT_I:
343 : 546473 : if (strcmp (arg, "-"))
344 : 546473 : add_path (xstrdup (arg), INC_BRACKET, 0, true);
345 : : else
346 : : {
347 : 0 : if (quote_chain_split)
348 : 0 : error ("%<-I-%> specified twice");
349 : 0 : quote_chain_split = true;
350 : 0 : split_quote_chain ();
351 : 0 : inform (input_location, "obsolete option %<-I-%> used, "
352 : : "please use %<-iquote%> instead");
353 : : }
354 : : break;
355 : :
356 : 25 : case OPT_M:
357 : 25 : case OPT_MM:
358 : : /* When doing dependencies with -M or -MM, suppress normal
359 : : preprocessed output, but still do -dM etc. as software
360 : : depends on this. Preprocessed output does occur if -MD, -MMD
361 : : or environment var dependency generation is used. */
362 : 25 : cpp_opts->deps.style = (code == OPT_M ? DEPS_SYSTEM : DEPS_USER);
363 : 25 : flag_no_output = 1;
364 : 25 : break;
365 : :
366 : 5832 : case OPT_MD:
367 : 5832 : case OPT_MMD:
368 : 5832 : cpp_opts->deps.style = (code == OPT_MD ? DEPS_SYSTEM : DEPS_USER);
369 : 5832 : cpp_opts->deps.need_preprocessor_output = true;
370 : 5832 : deps_file = arg;
371 : 5832 : break;
372 : :
373 : 51 : case OPT_fdeps_format_:
374 : : /* https://wg21.link/p1689r5 */
375 : 51 : if (!strcmp (arg, "p1689r5"))
376 : 48 : cpp_opts->deps.fdeps_format = FDEPS_FMT_P1689R5;
377 : : else
378 : 3 : error ("%<-fdeps-format=%> unknown format %qs", arg);
379 : : break;
380 : :
381 : 63 : case OPT_fdeps_file_:
382 : 63 : deps_seen = true;
383 : 63 : fdeps_file = arg;
384 : 63 : break;
385 : :
386 : 63 : case OPT_fdeps_target_:
387 : 63 : deps_seen = true;
388 : 63 : defer_opt (code, arg);
389 : 63 : break;
390 : :
391 : 5776 : case OPT_MF:
392 : 5776 : deps_seen = true;
393 : 5776 : deps_file = arg;
394 : 5776 : break;
395 : :
396 : 3 : case OPT_MG:
397 : 3 : deps_seen = true;
398 : 3 : cpp_opts->deps.missing_files = true;
399 : 3 : break;
400 : :
401 : 5761 : case OPT_MP:
402 : 5761 : deps_seen = true;
403 : 5761 : cpp_opts->deps.phony_targets = true;
404 : 5761 : break;
405 : :
406 : 0 : case OPT_Mmodules:
407 : : /* Do not set deps_seen, so the user can unconditionally turn
408 : : this on or off. */
409 : 0 : cpp_opts->deps.modules = true;
410 : 0 : break;
411 : :
412 : 3 : case OPT_Mno_modules:
413 : : /* Do not set deps_seen, so the user can unconditionally turn
414 : : this on or off. */
415 : 3 : cpp_opts->deps.modules = false;
416 : 3 : break;
417 : :
418 : 5828 : case OPT_MQ:
419 : 5828 : case OPT_MT:
420 : 5828 : deps_seen = true;
421 : 5828 : defer_opt (code, arg);
422 : 5828 : break;
423 : :
424 : 43 : case OPT_P:
425 : 43 : flag_no_line_commands = 1;
426 : 43 : break;
427 : :
428 : 61 : case OPT_U:
429 : 61 : defer_opt (code, arg);
430 : 61 : break;
431 : :
432 : 10851 : case OPT_Wall:
433 : : /* ??? Don't add new options here. Use LangEnabledBy in c.opt. */
434 : :
435 : 10851 : cpp_opts->warn_num_sign_change = value;
436 : 10851 : break;
437 : :
438 : 10933 : case OPT_Wunknown_pragmas:
439 : : /* Set to greater than 1, so that even unknown pragmas in
440 : : system headers will be warned about. */
441 : : /* ??? There is no way to handle this automatically for now. */
442 : 10933 : warn_unknown_pragmas = value * 2;
443 : 10933 : break;
444 : :
445 : 3409 : case OPT_ansi:
446 : 3409 : if (!c_dialect_cxx ())
447 : 3263 : set_std_c89 (false, true);
448 : : else
449 : 146 : set_std_cxx98 (true);
450 : : break;
451 : :
452 : 1647 : case OPT_d:
453 : 1647 : handle_OPT_d (arg);
454 : 1647 : break;
455 : :
456 : 13808 : case OPT_Wabi_:
457 : 13808 : warn_abi = true;
458 : 13808 : if (value == 1)
459 : : {
460 : 0 : warning (0, "%<-Wabi=1%> is not supported, using =2");
461 : 0 : value = 2;
462 : : }
463 : 13808 : warn_abi_version = value;
464 : 13808 : break;
465 : :
466 : 18 : case OPT_fcanonical_system_headers:
467 : 18 : cpp_opts->canonical_system_headers = value;
468 : 18 : break;
469 : :
470 : 12 : case OPT_fcond_mismatch:
471 : 12 : if (!c_dialect_cxx ())
472 : : {
473 : 12 : flag_cond_mismatch = value;
474 : 12 : break;
475 : : }
476 : 0 : warning (0, "switch %qs is no longer supported", option->opt_text);
477 : 0 : break;
478 : :
479 : 308 : case OPT_fbuiltin_:
480 : 308 : if (value)
481 : : result = false;
482 : : else
483 : 308 : disable_builtin_function (arg);
484 : : break;
485 : :
486 : 1090 : case OPT_fdirectives_only:
487 : 1090 : cpp_opts->directives_only = value;
488 : 1090 : break;
489 : :
490 : 7 : case OPT_fdollars_in_identifiers:
491 : 7 : cpp_opts->dollars_in_ident = value;
492 : 7 : break;
493 : :
494 : 8 : case OPT_fmacro_prefix_map_:
495 : 8 : add_macro_prefix_map (arg);
496 : 8 : break;
497 : :
498 : 1031 : case OPT_ffreestanding:
499 : 1031 : value = !value;
500 : : /* Fall through. */
501 : 1039 : case OPT_fhosted:
502 : 1039 : flag_hosted = value;
503 : 1039 : flag_no_builtin = !value;
504 : 1039 : break;
505 : :
506 : 0 : case OPT_fconstant_string_class_:
507 : 0 : constant_string_class_name = arg;
508 : 0 : break;
509 : :
510 : 0 : case OPT_fextended_identifiers:
511 : 0 : cpp_opts->extended_identifiers = value;
512 : 0 : break;
513 : :
514 : 4 : case OPT_fmax_include_depth_:
515 : 4 : cpp_opts->max_include_depth = value;
516 : 4 : break;
517 : :
518 : 4 : case OPT_foperator_names:
519 : 4 : cpp_opts->operator_names = value;
520 : 4 : break;
521 : :
522 : 0 : case OPT_fpch_deps:
523 : 0 : cpp_opts->restore_pch_deps = value;
524 : 0 : break;
525 : :
526 : 475 : case OPT_fpch_preprocess:
527 : 475 : flag_pch_preprocess = value;
528 : 475 : break;
529 : :
530 : 1151 : case OPT_fpermissive:
531 : 1151 : flag_permissive = value;
532 : 1151 : global_dc->m_permissive = value;
533 : 1151 : break;
534 : :
535 : 525 : case OPT_fpreprocessed:
536 : 525 : cpp_opts->preprocessed = value;
537 : 525 : break;
538 : :
539 : 2 : case OPT_fdebug_cpp:
540 : 2 : cpp_opts->debug = value;
541 : 2 : break;
542 : :
543 : 1 : case OPT_ftrack_macro_expansion:
544 : 1 : if (value)
545 : 0 : value = 2;
546 : : /* Fall Through. */
547 : :
548 : 483 : case OPT_ftrack_macro_expansion_:
549 : 483 : if (arg && *arg != '\0')
550 : 482 : cpp_opts->track_macro_expansion = value;
551 : : else
552 : 1 : cpp_opts->track_macro_expansion = 2;
553 : : break;
554 : :
555 : 85 : case OPT_fexec_charset_:
556 : 85 : cpp_opts->narrow_charset = arg;
557 : 85 : break;
558 : :
559 : 2 : case OPT_fwide_exec_charset_:
560 : 2 : cpp_opts->wide_charset = arg;
561 : 2 : break;
562 : :
563 : 93 : case OPT_finput_charset_:
564 : 93 : cpp_opts->input_charset = arg;
565 : 93 : cpp_opts->cpp_input_charset_explicit = 1;
566 : 93 : break;
567 : :
568 : 28 : case OPT_ftemplate_depth_:
569 : 28 : max_tinst_depth = value;
570 : 28 : break;
571 : :
572 : 21 : case OPT_fvisibility_inlines_hidden:
573 : 21 : visibility_options.inlines_hidden = value;
574 : 21 : break;
575 : :
576 : 22 : case OPT_femit_struct_debug_baseonly:
577 : 22 : set_struct_debug_option (&global_options, loc, "base");
578 : 22 : break;
579 : :
580 : 8 : case OPT_femit_struct_debug_reduced:
581 : 8 : set_struct_debug_option (&global_options, loc,
582 : : "dir:ord:sys,dir:gen:any,ind:base");
583 : 8 : break;
584 : :
585 : 12 : case OPT_femit_struct_debug_detailed_:
586 : 12 : set_struct_debug_option (&global_options, loc, arg);
587 : 12 : break;
588 : :
589 : 17 : case OPT_fext_numeric_literals:
590 : 17 : cpp_opts->ext_numeric_literals = value;
591 : 17 : break;
592 : :
593 : 4 : case OPT_idirafter:
594 : 4 : add_path (xstrdup (arg), INC_AFTER, 0, true);
595 : 4 : break;
596 : :
597 : 10107 : case OPT_imacros:
598 : 10107 : case OPT_include:
599 : 10107 : defer_opt (code, arg);
600 : 10107 : break;
601 : :
602 : 5302 : case OPT_imultilib:
603 : 5302 : imultilib = arg;
604 : 5302 : break;
605 : :
606 : 201172 : case OPT_iprefix:
607 : 201172 : iprefix = arg;
608 : 201172 : break;
609 : :
610 : 2862 : case OPT_iquote:
611 : 2862 : add_path (xstrdup (arg), INC_QUOTE, 0, true);
612 : 2862 : break;
613 : :
614 : 0 : case OPT_isysroot:
615 : 0 : sysroot = arg;
616 : 0 : break;
617 : :
618 : 454995 : case OPT_isystem:
619 : 454995 : add_path (xstrdup (arg), INC_SYSTEM, 0, true);
620 : 454995 : break;
621 : :
622 : 0 : case OPT_iwithprefix:
623 : 0 : add_prefixed_path (arg, INC_SYSTEM);
624 : 0 : break;
625 : :
626 : 0 : case OPT_iwithprefixbefore:
627 : 0 : add_prefixed_path (arg, INC_BRACKET);
628 : 0 : break;
629 : :
630 : 81 : case OPT__embed_dir_:
631 : 81 : add_path (xstrdup (arg), INC_EMBED, 0, true);
632 : 81 : break;
633 : :
634 : 981 : case OPT_lang_asm:
635 : 981 : cpp_set_lang (parse_in, CLK_ASM);
636 : 981 : cpp_opts->dollars_in_ident = false;
637 : 981 : break;
638 : :
639 : 60 : case OPT_nostdinc:
640 : 60 : std_inc = false;
641 : 60 : break;
642 : :
643 : 109627 : case OPT_nostdinc__:
644 : 109627 : std_cxx_inc = false;
645 : 109627 : break;
646 : :
647 : 203264 : case OPT_o:
648 : 203264 : if (!out_fname)
649 : 203264 : out_fname = arg;
650 : : else
651 : 0 : error ("output filename specified twice");
652 : : break;
653 : :
654 : 0 : case OPT_print_objc_runtime_info:
655 : 0 : print_struct_values = 1;
656 : 0 : break;
657 : :
658 : 2 : case OPT_remap:
659 : 2 : cpp_opts->remap = 1;
660 : 2 : break;
661 : :
662 : 13938 : case OPT_std_c__98:
663 : 13938 : case OPT_std_gnu__98:
664 : 13938 : if (!preprocessing_asm_p)
665 : 13938 : set_std_cxx98 (code == OPT_std_c__98 /* ISO */);
666 : : break;
667 : :
668 : 5547 : case OPT_std_c__11:
669 : 5547 : case OPT_std_gnu__11:
670 : 5547 : if (!preprocessing_asm_p)
671 : 5547 : set_std_cxx11 (code == OPT_std_c__11 /* ISO */);
672 : : break;
673 : :
674 : 1244 : case OPT_std_c__14:
675 : 1244 : case OPT_std_gnu__14:
676 : 1244 : if (!preprocessing_asm_p)
677 : 1244 : set_std_cxx14 (code == OPT_std_c__14 /* ISO */);
678 : : break;
679 : :
680 : 30373 : case OPT_std_c__17:
681 : 30373 : case OPT_std_gnu__17:
682 : 30373 : if (!preprocessing_asm_p)
683 : 30373 : set_std_cxx17 (code == OPT_std_c__17 /* ISO */);
684 : : break;
685 : :
686 : 4916 : case OPT_std_c__20:
687 : 4916 : case OPT_std_gnu__20:
688 : 4916 : if (!preprocessing_asm_p)
689 : 4916 : set_std_cxx20 (code == OPT_std_c__20 /* ISO */);
690 : : break;
691 : :
692 : 1865 : case OPT_std_c__23:
693 : 1865 : case OPT_std_gnu__23:
694 : 1865 : if (!preprocessing_asm_p)
695 : 1865 : set_std_cxx23 (code == OPT_std_c__23 /* ISO */);
696 : : break;
697 : :
698 : 23423 : case OPT_std_c__26:
699 : 23423 : case OPT_std_gnu__26:
700 : 23423 : if (!preprocessing_asm_p)
701 : 23423 : set_std_cxx26 (code == OPT_std_c__26 /* ISO */);
702 : : break;
703 : :
704 : 190 : case OPT_std_c90:
705 : 190 : case OPT_std_iso9899_199409:
706 : 190 : if (!preprocessing_asm_p)
707 : 190 : set_std_c89 (code == OPT_std_iso9899_199409 /* c94 */, true /* ISO */);
708 : : break;
709 : :
710 : 2951 : case OPT_std_gnu90:
711 : 2951 : if (!preprocessing_asm_p)
712 : 2951 : set_std_c89 (false /* c94 */, false /* ISO */);
713 : : break;
714 : :
715 : 572 : case OPT_std_c99:
716 : 572 : if (!preprocessing_asm_p)
717 : 571 : set_std_c99 (true /* ISO */);
718 : : break;
719 : :
720 : 610 : case OPT_std_gnu99:
721 : 610 : if (!preprocessing_asm_p)
722 : 610 : set_std_c99 (false /* ISO */);
723 : : break;
724 : :
725 : 508 : case OPT_std_c11:
726 : 508 : if (!preprocessing_asm_p)
727 : 508 : set_std_c11 (true /* ISO */);
728 : : break;
729 : :
730 : 3690 : case OPT_std_gnu11:
731 : 3690 : if (!preprocessing_asm_p)
732 : 3690 : set_std_c11 (false /* ISO */);
733 : : break;
734 : :
735 : 38 : case OPT_std_c17:
736 : 38 : if (!preprocessing_asm_p)
737 : 38 : set_std_c17 (true /* ISO */);
738 : : break;
739 : :
740 : 784 : case OPT_std_gnu17:
741 : 784 : if (!preprocessing_asm_p)
742 : 784 : set_std_c17 (false /* ISO */);
743 : : break;
744 : :
745 : 830 : case OPT_std_c23:
746 : 830 : if (!preprocessing_asm_p)
747 : 830 : set_std_c23 (true /* ISO */);
748 : : break;
749 : :
750 : 191 : case OPT_std_gnu23:
751 : 191 : if (!preprocessing_asm_p)
752 : 191 : set_std_c23 (false /* ISO */);
753 : : break;
754 : :
755 : 146 : case OPT_std_c2y:
756 : 146 : if (!preprocessing_asm_p)
757 : 146 : set_std_c2y (true /* ISO */);
758 : : break;
759 : :
760 : 8 : case OPT_std_gnu2y:
761 : 8 : if (!preprocessing_asm_p)
762 : 8 : set_std_c2y (false /* ISO */);
763 : : break;
764 : :
765 : 20 : case OPT_trigraphs:
766 : 20 : cpp_opts->trigraphs = 1;
767 : 20 : break;
768 : :
769 : 2399 : case OPT_traditional_cpp:
770 : 2399 : cpp_opts->traditional = 1;
771 : 2399 : break;
772 : :
773 : 0 : case OPT_fsearch_include_path:
774 : 0 : cpp_opts->main_search = CMS_user;
775 : 0 : break;
776 : :
777 : 0 : case OPT_fsearch_include_path_:
778 : 0 : if (!strcmp (arg, "user"))
779 : 0 : cpp_opts->main_search = CMS_user;
780 : 0 : else if (!strcmp (arg, "system"))
781 : 0 : cpp_opts->main_search = CMS_system;
782 : : else
783 : 0 : error ("invalid argument %qs to %<-fsearch-include-path%>", arg);
784 : : break;
785 : :
786 : 112 : case OPT_v:
787 : 112 : verbose = true;
788 : 112 : break;
789 : : }
790 : :
791 : 3284097 : switch (c_language)
792 : : {
793 : 1403270 : case clk_c:
794 : 1403270 : C_handle_option_auto (&global_options, &global_options_set,
795 : : scode, arg, value,
796 : : c_family_lang_mask, kind,
797 : : loc, handlers, global_dc);
798 : 1403270 : break;
799 : :
800 : 0 : case clk_objc:
801 : 0 : ObjC_handle_option_auto (&global_options, &global_options_set,
802 : : scode, arg, value,
803 : : c_family_lang_mask, kind,
804 : : loc, handlers, global_dc);
805 : 0 : break;
806 : :
807 : 1880827 : case clk_cxx:
808 : 1880827 : CXX_handle_option_auto (&global_options, &global_options_set,
809 : : scode, arg, value,
810 : : c_family_lang_mask, kind,
811 : : loc, handlers, global_dc);
812 : 1880827 : break;
813 : :
814 : 0 : case clk_objcxx:
815 : 0 : ObjCXX_handle_option_auto (&global_options, &global_options_set,
816 : : scode, arg, value,
817 : : c_family_lang_mask, kind,
818 : : loc, handlers, global_dc);
819 : 0 : break;
820 : :
821 : 0 : default:
822 : 0 : gcc_unreachable ();
823 : : }
824 : :
825 : 3284097 : cpp_handle_option_auto (&global_options, scode, cpp_opts);
826 : 3284097 : return result;
827 : : }
828 : :
829 : : /* Default implementation of TARGET_HANDLE_C_OPTION. */
830 : :
831 : : bool
832 : 0 : default_handle_c_option (size_t code ATTRIBUTE_UNUSED,
833 : : const char *arg ATTRIBUTE_UNUSED,
834 : : int value ATTRIBUTE_UNUSED)
835 : : {
836 : 0 : return false;
837 : : }
838 : :
839 : : /* Post-switch processing. */
840 : : bool
841 : 203909 : c_common_post_options (const char **pfilename)
842 : : {
843 : : /* Canonicalize the input and output filenames. */
844 : 203909 : if (in_fnames == NULL)
845 : : {
846 : 0 : in_fnames = XNEWVEC (const char *, 1);
847 : 0 : in_fnames[0] = "";
848 : : }
849 : 203909 : else if (strcmp (in_fnames[0], "-") == 0)
850 : : {
851 : 407 : if (pch_file)
852 : 0 : error ("cannot use %<-%> as input filename for a precompiled header");
853 : :
854 : 407 : in_fnames[0] = "";
855 : : }
856 : :
857 : 203909 : if (out_fname == NULL || !strcmp (out_fname, "-"))
858 : 713 : out_fname = "";
859 : :
860 : 203909 : if (cpp_opts->deps.style == DEPS_NONE)
861 : 198052 : check_deps_environment_vars ();
862 : :
863 : 203909 : handle_deferred_opts ();
864 : :
865 : 203909 : sanitize_cpp_opts ();
866 : :
867 : 203909 : register_include_chains (parse_in, sysroot, iprefix, imultilib,
868 : 203909 : std_inc, std_cxx_inc && c_dialect_cxx (), verbose);
869 : :
870 : : #ifdef C_COMMON_OVERRIDE_OPTIONS
871 : : /* Some machines may reject certain combinations of C
872 : : language-specific options. */
873 : : C_COMMON_OVERRIDE_OPTIONS;
874 : : #endif
875 : :
876 : 203909 : if (flag_excess_precision == EXCESS_PRECISION_DEFAULT)
877 : 348829 : flag_excess_precision = (flag_iso ? EXCESS_PRECISION_STANDARD
878 : : : EXCESS_PRECISION_FAST);
879 : :
880 : : /* ISO C restricts floating-point expression contraction to within
881 : : source-language expressions (-ffp-contract=on, currently an alias
882 : : for -ffp-contract=off). */
883 : 203909 : if (flag_iso
884 : 55847 : && !c_dialect_cxx ()
885 : 5537 : && (OPTION_SET_P (flag_fp_contract_mode)
886 : : == (enum fp_contract_mode) 0)
887 : 5537 : && flag_unsafe_math_optimizations == 0)
888 : 5532 : flag_fp_contract_mode = FP_CONTRACT_OFF;
889 : :
890 : : /* C language modes before C99 enable -fpermissive by default, but
891 : : only if -pedantic-errors is not specified. Also treat
892 : : -fno-permissive as a subset of -pedantic-errors that does not
893 : : reject certain GNU extensions also present the defaults for later
894 : : language modes. */
895 : 203909 : if (!c_dialect_cxx ()
896 : 107406 : && !flag_isoc99
897 : 6395 : && !global_dc->m_pedantic_errors
898 : 5407 : && !OPTION_SET_P (flag_permissive))
899 : : {
900 : 5406 : flag_permissive = 1;
901 : 5406 : global_dc->m_permissive = 1;
902 : : }
903 : :
904 : : /* If we are compiling C, and we are outside of a standards mode,
905 : : we can permit the new values from ISO/IEC TS 18661-3 for
906 : : FLT_EVAL_METHOD. Otherwise, we must restrict the possible values to
907 : : the set specified in ISO C99/C11. */
908 : 203909 : if (!flag_iso
909 : 148062 : && !c_dialect_cxx ()
910 : 101869 : && (OPTION_SET_P (flag_permitted_flt_eval_methods)
911 : : == PERMITTED_FLT_EVAL_METHODS_DEFAULT))
912 : 101868 : flag_permitted_flt_eval_methods = PERMITTED_FLT_EVAL_METHODS_TS_18661;
913 : : else
914 : 102041 : flag_permitted_flt_eval_methods = PERMITTED_FLT_EVAL_METHODS_C11;
915 : :
916 : : /* C23 Annex F does not permit certain built-in functions to raise
917 : : "inexact". */
918 : 203909 : if (flag_isoc23)
919 : 94810 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
920 : : flag_fp_int_builtin_inexact, 0);
921 : :
922 : : /* By default we use C99 inline semantics in GNU99 or C99 mode. C99
923 : : inline semantics are not supported in GNU89 or C89 mode. */
924 : 203909 : if (flag_gnu89_inline == -1)
925 : 203471 : flag_gnu89_inline = !flag_isoc99;
926 : 438 : else if (!flag_gnu89_inline && !flag_isoc99)
927 : 1 : error ("%<-fno-gnu89-inline%> is only supported in GNU99 or C99 mode");
928 : :
929 : : /* Default to ObjC sjlj exception handling if NeXT runtime < v2. */
930 : 203909 : if (flag_objc_sjlj_exceptions < 0)
931 : 407818 : flag_objc_sjlj_exceptions = (flag_next_runtime && flag_objc_abi < 2);
932 : 203909 : if (flag_objc_exceptions && !flag_objc_sjlj_exceptions)
933 : 0 : flag_exceptions = 1;
934 : :
935 : : /* If -ffreestanding, -fno-hosted or -fno-builtin then disable
936 : : pattern recognition. */
937 : 203909 : if (flag_no_builtin)
938 : 760 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
939 : : flag_tree_loop_distribute_patterns, 0);
940 : :
941 : : /* -Woverlength-strings is off by default, but is enabled by -Wpedantic.
942 : : It is never enabled in C++, as the minimum limit is not normative
943 : : in that standard. */
944 : 203909 : if (c_dialect_cxx ())
945 : 96503 : warn_overlength_strings = 0;
946 : :
947 : : /* Wmain is enabled by default in C++ but not in C. */
948 : : /* Wmain is disabled by default for -ffreestanding (!flag_hosted),
949 : : even if -Wall or -Wpedantic was given (warn_main will be 2 if set
950 : : by -Wall, 1 if set by -Wmain). */
951 : 203909 : if (warn_main == -1)
952 : 245161 : warn_main = (c_dialect_cxx () && flag_hosted) ? 1 : 0;
953 : 55042 : else if (warn_main == 2)
954 : 54721 : warn_main = flag_hosted ? 1 : 0;
955 : :
956 : : /* In C, -Wall and -Wc++-compat enable -Wenum-compare; if it has not
957 : : yet been set, it is disabled by default. In C++, it is enabled
958 : : by default. */
959 : 203909 : if (warn_enum_compare == -1)
960 : 194451 : warn_enum_compare = c_dialect_cxx () ? 1 : 0;
961 : :
962 : : /* -Wpacked-bitfield-compat is on by default for the C languages. The
963 : : warning is issued in stor-layout.cc which is not part of the front-end so
964 : : we need to selectively turn it on here. */
965 : 203909 : if (warn_packed_bitfield_compat == -1)
966 : 203901 : warn_packed_bitfield_compat = 1;
967 : :
968 : : /* Special format checking options don't work without -Wformat; warn if
969 : : they are used. */
970 : 203909 : if (!warn_format)
971 : : {
972 : 192710 : warning (OPT_Wformat_y2k,
973 : : "%<-Wformat-y2k%> ignored without %<-Wformat%>");
974 : 192710 : warning (OPT_Wformat_extra_args,
975 : : "%<-Wformat-extra-args%> ignored without %<-Wformat%>");
976 : 192710 : warning (OPT_Wformat_zero_length,
977 : : "%<-Wformat-zero-length%> ignored without %<-Wformat%>");
978 : 192710 : warning (OPT_Wformat_nonliteral,
979 : : "%<-Wformat-nonliteral%> ignored without %<-Wformat%>");
980 : 192710 : warning (OPT_Wformat_contains_nul,
981 : : "%<-Wformat-contains-nul%> ignored without %<-Wformat%>");
982 : 192710 : warning (OPT_Wformat_security,
983 : : "%<-Wformat-security%> ignored without %<-Wformat%>");
984 : : }
985 : :
986 : : /* -Wimplicit-function-declaration is enabled by default for C99. */
987 : 203909 : if (warn_implicit_function_declaration == -1)
988 : 195591 : warn_implicit_function_declaration = flag_isoc99;
989 : :
990 : : /* -Wimplicit-int is enabled by default for C99. */
991 : 203909 : if (warn_implicit_int == -1)
992 : 195649 : warn_implicit_int = flag_isoc99;
993 : :
994 : : /* -Wold-style-definition is enabled by default for C23. */
995 : 203909 : if (warn_old_style_definition == -1)
996 : 199619 : warn_old_style_definition = flag_isoc23;
997 : :
998 : : /* -Wshift-overflow is enabled by default in C99 and C++11 modes. */
999 : 203909 : if (warn_shift_overflow == -1)
1000 : 387307 : warn_shift_overflow = cxx_dialect >= cxx11 || flag_isoc99;
1001 : :
1002 : : /* -Wmissing-parameter-name is enabled by -pedantic before C23,
1003 : : and for -Wc11-c23-compat. */
1004 : 203909 : if (warn_missing_parameter_name == -1)
1005 : 203906 : warn_missing_parameter_name
1006 : 46493 : = ((pedantic && !flag_isoc23 && warn_c11_c23_compat != 0)
1007 : 250444 : || warn_c11_c23_compat > 0);
1008 : :
1009 : : /* Likewise for -Wfree-labels. */
1010 : 203909 : if (warn_free_labels == -1)
1011 : 46493 : warn_free_labels = ((pedantic && !flag_isoc23 && warn_c11_c23_compat != 0)
1012 : 250444 : || warn_c11_c23_compat > 0);
1013 : :
1014 : 203909 : if (warn_deprecated_non_prototype == -1)
1015 : 203904 : warn_deprecated_non_prototype = warn_c11_c23_compat > 0;
1016 : :
1017 : : /* -Wshift-negative-value is enabled by -Wextra in C99 and C++11 to C++17
1018 : : modes. */
1019 : 203909 : if (warn_shift_negative_value == -1)
1020 : 407778 : warn_shift_negative_value = (extra_warnings
1021 : 7749 : && (cxx_dialect >= cxx11 || flag_isoc99)
1022 : 407899 : && cxx_dialect < cxx20);
1023 : :
1024 : : /* -Wregister is enabled by default in C++17. */
1025 : 203909 : SET_OPTION_IF_UNSET (&global_options, &global_options_set, warn_register,
1026 : : cxx_dialect >= cxx17);
1027 : :
1028 : : /* Explicit -Wdeprecated turns on warnings from later standards. */
1029 : 1595083 : auto deprecated_in = [&](enum cxx_dialect d)
1030 : : {
1031 : 1391174 : if (OPTION_SET_P (warn_deprecated)) return !!warn_deprecated;
1032 : 1389580 : return (warn_deprecated && cxx_dialect >= d);
1033 : : };
1034 : :
1035 : : /* -Wcomma-subscript is enabled by default in C++20. */
1036 : 203909 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
1037 : : warn_comma_subscript,
1038 : : cxx_dialect >= cxx23
1039 : : || deprecated_in (cxx20));
1040 : :
1041 : : /* -Wvolatile is enabled by default in C++20. */
1042 : 203909 : SET_OPTION_IF_UNSET (&global_options, &global_options_set, warn_volatile,
1043 : : deprecated_in (cxx20));
1044 : :
1045 : : /* -Wdeprecated-enum-enum-conversion is enabled by default in C++20. */
1046 : 203909 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
1047 : : warn_deprecated_enum_enum_conv,
1048 : : deprecated_in (cxx20));
1049 : :
1050 : : /* -Wdeprecated-enum-float-conversion is enabled by default in C++20. */
1051 : 203909 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
1052 : : warn_deprecated_enum_float_conv,
1053 : : deprecated_in (cxx20));
1054 : :
1055 : : /* -Wdeprecated-literal-operator is enabled by default in C++23. */
1056 : 203909 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
1057 : : warn_deprecated_literal_operator,
1058 : : deprecated_in (cxx23));
1059 : :
1060 : : /* -Warray-compare is enabled by default in C++20. */
1061 : 203909 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
1062 : : warn_array_compare,
1063 : : warn_array_compare || deprecated_in (cxx20));
1064 : :
1065 : : /* -Wdeprecated-variadic-comma-omission is enabled by default in C++26. */
1066 : 203909 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
1067 : : warn_deprecated_variadic_comma_omission,
1068 : : deprecated_in (cxx26));
1069 : :
1070 : : /* -Wtemplate-id-cdtor is enabled by default in C++20. */
1071 : 236128 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
1072 : : warn_template_id_cdtor,
1073 : : cxx_dialect >= cxx20 || warn_cxx20_compat);
1074 : :
1075 : : /* Declone C++ 'structors if -Os. */
1076 : 203909 : if (flag_declone_ctor_dtor == -1)
1077 : 203872 : flag_declone_ctor_dtor = optimize_size;
1078 : :
1079 : 203909 : if (flag_abi_compat_version == 1)
1080 : : {
1081 : 0 : warning (0, "%<-fabi-compat-version=1%> is not supported, using =2");
1082 : 0 : flag_abi_compat_version = 2;
1083 : : }
1084 : :
1085 : : /* Change flag_abi_version to be the actual current ABI level, for the
1086 : : benefit of c_cpp_builtins, and to make comparison simpler. */
1087 : 203909 : const int latest_abi_version = 21;
1088 : : /* Possibly different for non-default ABI fixes within a release. */
1089 : 203909 : const int default_abi_version = latest_abi_version;
1090 : : /* Generate compatibility aliases for ABI v18 (GCC 13) by default. */
1091 : 203909 : const int abi_compat_default = 18;
1092 : :
1093 : 203909 : if (flag_abi_version > latest_abi_version)
1094 : 0 : warning (0, "%<-fabi-version=%d%> is not supported, using =%d",
1095 : : flag_abi_version, latest_abi_version);
1096 : :
1097 : 203909 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
1098 : : flag_abi_version, default_abi_version);
1099 : :
1100 : : #define clamp(X) if (X == 0 || X > latest_abi_version) X = latest_abi_version
1101 : 203909 : clamp (flag_abi_version);
1102 : : /* Don't clamp warn_abi_version, let it be 0 or out of bounds. */
1103 : 203909 : clamp (flag_abi_compat_version);
1104 : : #undef clamp
1105 : :
1106 : : /* Default -Wabi= or -fabi-compat-version= from each other. */
1107 : 203909 : if (warn_abi_version == -1 && flag_abi_compat_version != -1)
1108 : 192 : warn_abi_version = flag_abi_compat_version;
1109 : 203717 : else if (flag_abi_compat_version == -1 && warn_abi_version != -1)
1110 : 13761 : flag_abi_compat_version = warn_abi_version;
1111 : 189956 : else if (warn_abi_version == -1 && flag_abi_compat_version == -1)
1112 : : {
1113 : 189911 : warn_abi_version = 0;
1114 : 189911 : if (flag_abi_version == default_abi_version)
1115 : 189679 : flag_abi_compat_version = abi_compat_default;
1116 : : else
1117 : 232 : flag_abi_compat_version = latest_abi_version;
1118 : : }
1119 : :
1120 : : /* Allow warnings vs ABI versions beyond what we currently support. */
1121 : 203909 : if (warn_abi_version == 0)
1122 : 189926 : warn_abi_version = 1000;
1123 : :
1124 : : /* By default, enable the new inheriting constructor semantics along with ABI
1125 : : 11. New and old should coexist fine, but it is a change in what
1126 : : artificial symbols are generated. */
1127 : 407562 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
1128 : : flag_new_inheriting_ctors,
1129 : : abi_version_at_least (11));
1130 : :
1131 : : /* For GCC 7, only enable DR150 resolution by default if -std=c++17. */
1132 : 203909 : SET_OPTION_IF_UNSET (&global_options, &global_options_set, flag_new_ttp,
1133 : : cxx_dialect >= cxx17);
1134 : :
1135 : : /* C++11 guarantees forward progress. */
1136 : 381284 : SET_OPTION_IF_UNSET (&global_options, &global_options_set, flag_finite_loops,
1137 : : optimize >= 2 && cxx_dialect >= cxx11);
1138 : :
1139 : : /* It's OK to discard calls to pure/const functions that might throw. */
1140 : 203909 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
1141 : : flag_delete_dead_exceptions, true);
1142 : :
1143 : 203909 : if (cxx_dialect >= cxx11)
1144 : : {
1145 : : /* If we're allowing C++0x constructs, don't warn about C++98
1146 : : identifiers which are keywords in C++0x. */
1147 : 82489 : warn_cxx11_compat = 0;
1148 : 82489 : cpp_opts->cpp_warn_cxx11_compat = 0;
1149 : :
1150 : 82489 : if (warn_narrowing == -1)
1151 : 80330 : warn_narrowing = 1;
1152 : :
1153 : : /* Unless -f{,no-}ext-numeric-literals has been used explicitly,
1154 : : for -std=c++{11,14,17,20,23,26} default to
1155 : : -fno-ext-numeric-literals. */
1156 : 82489 : if (flag_iso && !OPTION_SET_P (flag_ext_numeric_literals))
1157 : 41537 : cpp_opts->ext_numeric_literals = 0;
1158 : : }
1159 : 121420 : else if (warn_narrowing == -1)
1160 : 120934 : warn_narrowing = 0;
1161 : :
1162 : 203909 : if (cxx_dialect >= cxx20)
1163 : : {
1164 : : /* Don't warn about C++20 compatibility changes in C++20 or later. */
1165 : 30154 : warn_cxx20_compat = 0;
1166 : 30154 : cpp_opts->cpp_warn_cxx20_compat = 0;
1167 : : }
1168 : 203909 : if (cxx_dialect >= cxx26)
1169 : : /* Don't warn about C++26 compatibility changes in C++26 or later. */
1170 : 23377 : warn_cxx26_compat = 0;
1171 : :
1172 : : /* C++17 has stricter evaluation order requirements; let's use some of them
1173 : : for earlier C++ as well, so chaining works as expected. */
1174 : 203909 : if (c_dialect_cxx ()
1175 : 96503 : && flag_strong_eval_order == -1)
1176 : 117259 : flag_strong_eval_order = (cxx_dialect >= cxx17 ? 2 : 1);
1177 : :
1178 : 203909 : if (flag_implicit_constexpr && cxx_dialect < cxx14)
1179 : 0 : flag_implicit_constexpr = false;
1180 : :
1181 : : /* Global sized deallocation is new in C++14. */
1182 : 203909 : if (flag_sized_deallocation == -1)
1183 : 203905 : flag_sized_deallocation = (cxx_dialect >= cxx14);
1184 : :
1185 : : /* Pedwarn about invalid constexpr functions before C++23. */
1186 : 203909 : if (warn_invalid_constexpr == -1)
1187 : 203893 : warn_invalid_constexpr = (cxx_dialect < cxx23);
1188 : :
1189 : : /* char8_t support is implicitly enabled in C++20 and C23. */
1190 : 203909 : if (flag_char8_t == -1)
1191 : 328747 : flag_char8_t = (cxx_dialect >= cxx20) || flag_isoc23;
1192 : 203909 : cpp_opts->unsigned_utf8char = flag_char8_t ? 1 : cpp_opts->unsigned_char;
1193 : :
1194 : 203909 : cpp_opts->cpp_tabstop = global_dc->m_tabstop;
1195 : :
1196 : 203909 : if (flag_extern_tls_init)
1197 : : {
1198 : 203907 : if (!TARGET_SUPPORTS_ALIASES || !SUPPORTS_WEAK)
1199 : : {
1200 : : /* Lazy TLS initialization for a variable in another TU requires
1201 : : alias and weak reference support. */
1202 : : if (flag_extern_tls_init > 0)
1203 : : sorry ("external TLS initialization functions not supported "
1204 : : "on this target");
1205 : :
1206 : : flag_extern_tls_init = 0;
1207 : : }
1208 : : else
1209 : 203907 : flag_extern_tls_init = 1;
1210 : : }
1211 : :
1212 : : /* Enable by default only for C++ and C++ with ObjC extensions. */
1213 : 203909 : if (warn_return_type == -1 && c_dialect_cxx ())
1214 : 93014 : warn_return_type = 1;
1215 : :
1216 : : /* C++20 is the final version of concepts. We still use -fconcepts
1217 : : to know when concepts are enabled. */
1218 : 203909 : if (cxx_dialect >= cxx20)
1219 : 30154 : flag_concepts = 1;
1220 : :
1221 : : /* Coroutines are also a C++20 feature. */
1222 : 203909 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
1223 : : flag_coroutines, cxx_dialect >= cxx20);
1224 : :
1225 : : /* Enable lifetime extension of range based for temporaries for C++23. */
1226 : 203909 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
1227 : : flag_range_for_ext_temps, cxx_dialect >= cxx23);
1228 : :
1229 : : /* EnabledBy unfortunately can't specify value to use if set and
1230 : : LangEnabledBy can't specify multiple options with &&. For -Wunused
1231 : : or -Wunused -Wextra we want these to default to 3 unless user specified
1232 : : some other level explicitly. */
1233 : 203909 : if (warn_unused_but_set_parameter == 1)
1234 : 7593 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
1235 : : warn_unused_but_set_parameter, 3);
1236 : 203909 : if (warn_unused_but_set_variable == 1)
1237 : 10391 : SET_OPTION_IF_UNSET (&global_options, &global_options_set,
1238 : : warn_unused_but_set_variable, 3);
1239 : :
1240 : : /* -fimmediate-escalation has no effect when immediate functions are not
1241 : : supported. */
1242 : 203909 : if (flag_immediate_escalation && cxx_dialect < cxx20)
1243 : 173755 : flag_immediate_escalation = 0;
1244 : :
1245 : 203909 : if (num_in_fnames > 1)
1246 : 0 : error ("too many filenames given; type %<%s %s%> for usage",
1247 : : progname, "--help");
1248 : :
1249 : 203909 : if (flag_preprocess_only)
1250 : : {
1251 : : /* Open the output now. We must do so even if flag_no_output is
1252 : : on, because there may be other output than from the actual
1253 : : preprocessing (e.g. from -dM). */
1254 : 6214 : if (out_fname[0] == '\0')
1255 : 713 : out_stream = stdout;
1256 : : else
1257 : 5501 : out_stream = fopen (out_fname, "w");
1258 : :
1259 : 6214 : if (out_stream == NULL)
1260 : 0 : fatal_error (input_location, "opening output file %s: %m", out_fname);
1261 : :
1262 : 6214 : init_pp_output (out_stream);
1263 : : }
1264 : : else
1265 : : {
1266 : 197695 : init_c_lex ();
1267 : :
1268 : : /* When writing a PCH file, avoid reading some other PCH file,
1269 : : because the default address space slot then can't be used
1270 : : for the output PCH file. */
1271 : 197695 : if (pch_file)
1272 : : {
1273 : 428 : c_common_no_more_pch ();
1274 : : /* Only -g0 and -gdwarf* are supported with PCH, for other
1275 : : debug formats we warn here and refuse to load any PCH files. */
1276 : 428 : if (write_symbols != NO_DEBUG && write_symbols != DWARF2_DEBUG)
1277 : 0 : warning (OPT_Wdeprecated,
1278 : : "the %qs debug info cannot be used with "
1279 : : "pre-compiled headers",
1280 : : debug_set_names (write_symbols & ~DWARF2_DEBUG));
1281 : : /* Let libcpp know that the main file is a header so it won't
1282 : : complain about things like #include_next and #pragma once. */
1283 : 428 : cpp_opts->main_search = CMS_header;
1284 : : }
1285 : 197267 : else if (write_symbols != NO_DEBUG && write_symbols != DWARF2_DEBUG)
1286 : 316 : c_common_no_more_pch ();
1287 : :
1288 : : /* Yuk. WTF is this? I do know ObjC relies on it somewhere. */
1289 : 197695 : input_location = UNKNOWN_LOCATION;
1290 : : }
1291 : :
1292 : 203909 : struct cpp_callbacks *cb = cpp_get_callbacks (parse_in);
1293 : 203909 : cb->file_change = cb_file_change;
1294 : 203909 : cb->dir_change = cb_dir_change;
1295 : 203909 : if (lang_hooks.preprocess_options)
1296 : 96503 : lang_hooks.preprocess_options (parse_in);
1297 : 203909 : cpp_post_options (parse_in);
1298 : 203909 : init_global_opts_from_cpp (&global_options, cpp_get_options (parse_in));
1299 : : /* For C++23 and explicit -finput-charset=UTF-8, turn on -Winvalid-utf8
1300 : : by default and make it a pedwarn unless -Wno-invalid-utf8. */
1301 : 203909 : if (cxx_dialect >= cxx23
1302 : 25240 : && cpp_opts->cpp_input_charset_explicit
1303 : 23 : && strcmp (cpp_opts->input_charset, "UTF-8") == 0
1304 : 21 : && (cpp_opts->cpp_warn_invalid_utf8
1305 : 16 : || !global_options_set.x_warn_invalid_utf8))
1306 : : {
1307 : 18 : global_options.x_warn_invalid_utf8 = 1;
1308 : 28 : cpp_opts->cpp_warn_invalid_utf8 = cpp_opts->cpp_pedantic ? 2 : 1;
1309 : : }
1310 : :
1311 : : /* Let diagnostics infrastructure know how to convert input files the same
1312 : : way libcpp will do it, namely using the configured input charset and
1313 : : skipping a UTF-8 BOM if present. */
1314 : 203909 : diagnostic_initialize_input_context (global_dc,
1315 : : c_common_input_charset_cb, true);
1316 : 203909 : input_location = UNKNOWN_LOCATION;
1317 : :
1318 : 407818 : *pfilename = this_input_filename
1319 : 407818 : = cpp_read_main_file (parse_in, in_fnames[0],
1320 : : /* We'll inject preamble pieces if this is
1321 : : not preprocessed. */
1322 : 203909 : !cpp_opts->preprocessed);
1323 : :
1324 : : /* Don't do any compilation or preprocessing if there is no input file. */
1325 : 203909 : if (this_input_filename == NULL)
1326 : : {
1327 : 0 : errorcount++;
1328 : 0 : return false;
1329 : : }
1330 : :
1331 : 203909 : if (flag_working_directory
1332 : 42407 : && flag_preprocess_only && !flag_no_line_commands)
1333 : 2169 : pp_dir_change (parse_in, get_src_pwd ());
1334 : :
1335 : : /* Disable LTO output when outputting a precompiled header. */
1336 : 203909 : if (pch_file && flag_lto)
1337 : : {
1338 : 0 : flag_lto = 0;
1339 : 0 : flag_generate_lto = 0;
1340 : : }
1341 : :
1342 : 203909 : return flag_preprocess_only;
1343 : : }
1344 : :
1345 : : /* Front end initialization common to C, ObjC and C++. */
1346 : : bool
1347 : 203723 : c_common_init (void)
1348 : : {
1349 : : /* Set up preprocessor arithmetic. Must be done after call to
1350 : : c_common_nodes_and_builtins for type nodes to be good. */
1351 : 203723 : cpp_opts->precision = TYPE_PRECISION (intmax_type_node);
1352 : 203723 : cpp_opts->char_precision = TYPE_PRECISION (char_type_node);
1353 : 203723 : cpp_opts->int_precision = TYPE_PRECISION (integer_type_node);
1354 : 203723 : cpp_opts->wchar_precision = TYPE_PRECISION (wchar_type_node);
1355 : 203723 : cpp_opts->unsigned_wchar = TYPE_UNSIGNED (wchar_type_node);
1356 : 203723 : cpp_opts->bytes_big_endian = BYTES_BIG_ENDIAN;
1357 : :
1358 : : /* This can't happen until after wchar_precision and bytes_big_endian
1359 : : are known. */
1360 : 203723 : cpp_init_iconv (parse_in);
1361 : :
1362 : 203723 : if (version_flag)
1363 : : {
1364 : 109 : int i;
1365 : 109 : fputs ("Compiler executable checksum: ", stderr);
1366 : 1962 : for (i = 0; i < 16; i++)
1367 : 1744 : fprintf (stderr, "%02x", executable_checksum[i]);
1368 : 109 : putc ('\n', stderr);
1369 : : }
1370 : :
1371 : : /* Has to wait until now so that cpplib has its hash table. */
1372 : 203723 : init_pragma ();
1373 : :
1374 : 203723 : if (flag_preprocess_only)
1375 : : {
1376 : 6209 : c_init_preprocess ();
1377 : 6209 : c_finish_options ();
1378 : 6209 : preprocess_file (parse_in);
1379 : 6209 : return false;
1380 : : }
1381 : :
1382 : : return true;
1383 : : }
1384 : :
1385 : : /* Initialize the integrated preprocessor after debug output has been
1386 : : initialized; loop over each input file. */
1387 : : void
1388 : 197514 : c_common_parse_file (void)
1389 : : {
1390 : 197514 : auto dumps = g->get_dumps ();
1391 : 197514 : for (unsigned int i = 0;;)
1392 : : {
1393 : 197514 : c_finish_options ();
1394 : : /* Open the dump file to use for the original dump output
1395 : : here, to be used during parsing for the current file. */
1396 : 197514 : dumps->dump_start (TDI_original, &dump_flags);
1397 : 197514 : pch_init ();
1398 : 197514 : push_file_scope ();
1399 : 197514 : c_parse_file ();
1400 : 197231 : pop_file_scope ();
1401 : : /* And end the main input file, if the debug writer wants it */
1402 : 197231 : if (debug_hooks->start_end_main_source_file)
1403 : 40052 : (*debug_hooks->end_source_file) (0);
1404 : 197231 : if (++i >= num_in_fnames)
1405 : : break;
1406 : 0 : cpp_undef_all (parse_in);
1407 : 0 : cpp_clear_file_cache (parse_in);
1408 : 0 : this_input_filename
1409 : 0 : = cpp_read_main_file (parse_in, in_fnames[i]);
1410 : : /* If an input file is missing, abandon further compilation.
1411 : : cpplib has issued a diagnostic. */
1412 : 0 : if (!this_input_filename)
1413 : : break;
1414 : 0 : dumps->dump_finish (TDI_original);
1415 : : }
1416 : :
1417 : 197231 : c_parse_final_cleanups ();
1418 : 197219 : dumps->dump_finish (TDI_original);
1419 : 197219 : }
1420 : :
1421 : : /* Common finish hook for the C, ObjC and C++ front ends. */
1422 : : void
1423 : 203238 : c_common_finish (void)
1424 : : {
1425 : 203238 : FILE *deps_stream = NULL;
1426 : 203238 : FILE *fdeps_stream = NULL;
1427 : :
1428 : : /* Note that we write the dependencies even if there are errors. This is
1429 : : useful for handling outdated generated headers that now trigger errors
1430 : : (for example, with #error) which would be resolved by re-generating
1431 : : them. In a sense, this complements -MG. */
1432 : 203238 : if (cpp_opts->deps.style != DEPS_NONE)
1433 : : {
1434 : : /* If -M or -MM was seen without -MF, default output to the
1435 : : output stream. */
1436 : 5852 : if (!deps_file)
1437 : 22 : deps_stream = out_stream;
1438 : 5830 : else if (deps_file[0] == '-' && deps_file[1] == '\0')
1439 : 0 : deps_stream = stdout;
1440 : : else
1441 : : {
1442 : 11660 : deps_stream = fopen (deps_file, deps_append ? "a" : "w");
1443 : 5830 : if (!deps_stream)
1444 : 0 : fatal_error (input_location, "opening dependency file %s: %m",
1445 : : deps_file);
1446 : : }
1447 : : }
1448 : :
1449 : : /* When we call cpp_finish (), it may generate some diagnostics using
1450 : : locations it remembered from the preprocessing phase, e.g. for
1451 : : -Wunused-macros. So inform c_cpp_diagnostic () not to override those
1452 : : locations with input_location, which would be incorrect now. */
1453 : 203238 : override_libcpp_locations = false;
1454 : :
1455 : 203238 : if (cpp_opts->deps.fdeps_format != FDEPS_FMT_NONE)
1456 : : {
1457 : 36 : if (!fdeps_file)
1458 : 0 : fdeps_stream = out_stream;
1459 : 36 : else if (fdeps_file[0] == '-' && fdeps_file[1] == '\0')
1460 : 0 : fdeps_stream = stdout;
1461 : : else
1462 : : {
1463 : 36 : fdeps_stream = fopen (fdeps_file, "w");
1464 : 36 : if (!fdeps_stream)
1465 : 0 : fatal_error (input_location, "opening dependency file %s: %m",
1466 : : fdeps_file);
1467 : : }
1468 : 36 : if (fdeps_stream == deps_stream && fdeps_stream != stdout)
1469 : 0 : fatal_error (input_location, "%<-MF%> and %<-fdeps-file=%> cannot share an output file %s: %m",
1470 : : fdeps_file);
1471 : : }
1472 : :
1473 : : /* For performance, avoid tearing down cpplib's internal structures
1474 : : with cpp_destroy (). */
1475 : 203238 : cpp_finish (parse_in, deps_stream, fdeps_stream);
1476 : :
1477 : 5852 : if (deps_stream && deps_stream != out_stream && deps_stream != stdout
1478 : 209068 : && (ferror (deps_stream) || fclose (deps_stream)))
1479 : 0 : fatal_error (input_location, "closing dependency file %s: %m", deps_file);
1480 : :
1481 : 203238 : if (out_stream && (ferror (out_stream) || fclose (out_stream)))
1482 : 0 : fatal_error (input_location, "when writing output to %s: %m", out_fname);
1483 : 203238 : }
1484 : :
1485 : : /* Either of two environment variables can specify output of
1486 : : dependencies. Their value is either "OUTPUT_FILE" or "OUTPUT_FILE
1487 : : DEPS_TARGET", where OUTPUT_FILE is the file to write deps info to
1488 : : and DEPS_TARGET is the target to mention in the deps. They also
1489 : : result in dependency information being appended to the output file
1490 : : rather than overwriting it, and like Sun's compiler
1491 : : SUNPRO_DEPENDENCIES suppresses the dependency on the main file. */
1492 : : static void
1493 : 198052 : check_deps_environment_vars (void)
1494 : : {
1495 : 198052 : char *spec;
1496 : :
1497 : 198052 : spec = getenv ("DEPENDENCIES_OUTPUT");
1498 : 198052 : if (spec)
1499 : 0 : cpp_opts->deps.style = DEPS_USER;
1500 : : else
1501 : : {
1502 : 198052 : spec = getenv ("SUNPRO_DEPENDENCIES");
1503 : 198052 : if (spec)
1504 : : {
1505 : 0 : cpp_opts->deps.style = DEPS_SYSTEM;
1506 : 0 : cpp_opts->deps.ignore_main_file = true;
1507 : : }
1508 : : }
1509 : :
1510 : 0 : if (spec)
1511 : : {
1512 : : /* Find the space before the DEPS_TARGET, if there is one. */
1513 : 0 : char *s = strchr (spec, ' ');
1514 : 0 : if (s)
1515 : : {
1516 : : /* Let the caller perform MAKE quoting. */
1517 : 0 : defer_opt (OPT_MT, s + 1);
1518 : 0 : *s = '\0';
1519 : : }
1520 : :
1521 : : /* Command line -MF overrides environment variables and default. */
1522 : 0 : if (!deps_file)
1523 : 0 : deps_file = spec;
1524 : :
1525 : 0 : deps_append = 1;
1526 : 0 : deps_seen = true;
1527 : : }
1528 : 198052 : }
1529 : :
1530 : : /* Handle deferred command line switches. */
1531 : : static void
1532 : 203909 : handle_deferred_opts (void)
1533 : : {
1534 : : /* Avoid allocating the deps buffer if we don't need it.
1535 : : (This flag may be true without there having been -MT or -MQ
1536 : : options, but we'll still need the deps buffer.) */
1537 : 203909 : if (!deps_seen)
1538 : : return;
1539 : :
1540 : 5859 : if (mkdeps *deps = cpp_get_deps (parse_in))
1541 : 34804 : for (unsigned i = 0; i < deferred_count; i++)
1542 : : {
1543 : 28969 : struct deferred_opt *opt = &deferred_opts[i];
1544 : :
1545 : 28969 : if (opt->code == OPT_MT || opt->code == OPT_MQ)
1546 : 5828 : deps_add_target (deps, opt->arg, opt->code == OPT_MQ);
1547 : 23141 : else if (opt->code == OPT_fdeps_target_)
1548 : 42 : fdeps_add_target (deps, opt->arg, true);
1549 : : }
1550 : : }
1551 : :
1552 : : /* These settings are appropriate for GCC, but not necessarily so for
1553 : : cpplib as a library. */
1554 : : static void
1555 : 203909 : sanitize_cpp_opts (void)
1556 : : {
1557 : : /* If we don't know what style of dependencies to output, complain
1558 : : if any other dependency switches have been given. */
1559 : 203909 : if (deps_seen && cpp_opts->deps.style == DEPS_NONE)
1560 : 24 : error ("to generate dependencies you must specify either %<-M%> "
1561 : : "or %<-MM%>");
1562 : :
1563 : : /* -dM and dependencies suppress normal output; do it here so that
1564 : : the last -d[MDN] switch overrides earlier ones. */
1565 : 203909 : if (flag_dump_macros == 'M')
1566 : 80 : flag_no_output = 1;
1567 : :
1568 : : /* By default, -fdirectives-only implies -dD. This allows subsequent phases
1569 : : to perform proper macro expansion. */
1570 : 203909 : if (cpp_opts->directives_only && !cpp_opts->preprocessed && !flag_dump_macros)
1571 : 68 : flag_dump_macros = 'D';
1572 : :
1573 : : /* Disable -dD, -dN and -dI if normal output is suppressed. Allow
1574 : : -dM since at least glibc relies on -M -dM to work. */
1575 : : /* Also, flag_no_output implies flag_no_line_commands, always. */
1576 : 203909 : if (flag_no_output)
1577 : : {
1578 : 104 : if (flag_dump_macros != 'M')
1579 : 24 : flag_dump_macros = 0;
1580 : 104 : flag_dump_includes = 0;
1581 : 104 : flag_no_line_commands = 1;
1582 : : }
1583 : 203805 : else if (cpp_opts->deps.missing_files)
1584 : 1 : error ("%<-MG%> may only be used with %<-M%> or %<-MM%>");
1585 : :
1586 : 203909 : cpp_opts->unsigned_char = !flag_signed_char;
1587 : 203909 : cpp_opts->stdc_0_in_system_headers = STDC_0_IN_SYSTEM_HEADERS;
1588 : :
1589 : : /* Wlong-long is disabled by default. It is enabled by:
1590 : : [-Wpedantic | -Wtraditional] -std=[gnu|c]++98 ; or
1591 : : [-Wpedantic | -Wtraditional] -std=non-c99
1592 : :
1593 : : Either -Wlong-long or -Wno-long-long override any other settings.
1594 : : ??? These conditions should be handled in c.opt. */
1595 : 203909 : if (warn_long_long == -1)
1596 : : {
1597 : 156661 : warn_long_long = ((pedantic || warn_traditional)
1598 : 160256 : && (c_dialect_cxx () ? cxx_dialect == cxx98 : !flag_isoc99));
1599 : 160232 : cpp_opts->cpp_warn_long_long = warn_long_long;
1600 : : }
1601 : :
1602 : : /* If we're generating preprocessor output, emit current directory
1603 : : if explicitly requested or if debugging information is enabled.
1604 : : ??? Maybe we should only do it for debugging formats that
1605 : : actually output the current directory? */
1606 : 203909 : if (flag_working_directory == -1)
1607 : 202514 : flag_working_directory = (debug_info_level != DINFO_LEVEL_NONE);
1608 : :
1609 : 203909 : if (warn_implicit_fallthrough < 5)
1610 : 203905 : cpp_opts->cpp_warn_implicit_fallthrough = warn_implicit_fallthrough;
1611 : : else
1612 : 4 : cpp_opts->cpp_warn_implicit_fallthrough = 0;
1613 : :
1614 : 203909 : if (cpp_opts->directives_only)
1615 : : {
1616 : 109 : if (cpp_warn_unused_macros)
1617 : 4 : error ("%<-fdirectives-only%> is incompatible "
1618 : : "with %<-Wunused-macros%>");
1619 : 109 : if (cpp_opts->traditional)
1620 : 1 : error ("%<-fdirectives-only%> is incompatible with %<-traditional%>");
1621 : : }
1622 : 203909 : }
1623 : :
1624 : : /* Add include path with a prefix at the front of its name. */
1625 : : static void
1626 : 0 : add_prefixed_path (const char *suffix, incpath_kind chain)
1627 : : {
1628 : 0 : char *path;
1629 : 0 : const char *prefix;
1630 : 0 : size_t prefix_len, suffix_len;
1631 : :
1632 : 0 : suffix_len = strlen (suffix);
1633 : 0 : prefix = iprefix ? iprefix : cpp_GCC_INCLUDE_DIR;
1634 : 0 : prefix_len = iprefix ? strlen (iprefix) : cpp_GCC_INCLUDE_DIR_len;
1635 : :
1636 : 0 : path = (char *) xmalloc (prefix_len + suffix_len + 1);
1637 : 0 : memcpy (path, prefix, prefix_len);
1638 : 0 : memcpy (path + prefix_len, suffix, suffix_len);
1639 : 0 : path[prefix_len + suffix_len] = '\0';
1640 : :
1641 : 0 : add_path (path, chain, 0, false);
1642 : 0 : }
1643 : :
1644 : : /* Handle -D, -U, -A, -imacros, and the first -include. */
1645 : : static void
1646 : 203723 : c_finish_options (void)
1647 : : {
1648 : 203723 : if (!cpp_opts->preprocessed)
1649 : : {
1650 : 203198 : const line_map_ordinary *bltin_map
1651 : 203198 : = linemap_check_ordinary (linemap_add (line_table, LC_RENAME, 0,
1652 : : special_fname_builtin (), 0));
1653 : 203198 : cb_file_change (parse_in, bltin_map);
1654 : 203198 : linemap_line_start (line_table, 0, 1);
1655 : :
1656 : : /* Make sure all of the builtins about to be declared have
1657 : : BUILTINS_LOCATION has their location_t. */
1658 : 203198 : cpp_force_token_locations (parse_in, BUILTINS_LOCATION);
1659 : :
1660 : 203198 : cpp_init_builtins (parse_in, flag_hosted);
1661 : 203198 : c_cpp_builtins (parse_in);
1662 : :
1663 : : /* We're about to send user input to cpplib, so make it warn for
1664 : : things that we previously (when we sent it internal definitions)
1665 : : told it to not warn.
1666 : :
1667 : : C99 permits implementation-defined characters in identifiers.
1668 : : The documented meaning of -std= is to turn off extensions that
1669 : : conflict with the specified standard, and since a strictly
1670 : : conforming program cannot contain a '$', we do not condition
1671 : : their acceptance on the -std= setting. */
1672 : 203198 : cpp_opts->warn_dollars = (cpp_opts->cpp_pedantic && !cpp_opts->c99);
1673 : :
1674 : 203198 : const line_map_ordinary *cmd_map
1675 : 203198 : = linemap_check_ordinary (linemap_add (line_table, LC_RENAME, 0,
1676 : 203198 : _("<command-line>"), 0));
1677 : 203198 : cb_file_change (parse_in, cmd_map);
1678 : 203198 : linemap_line_start (line_table, 0, 1);
1679 : :
1680 : 203198 : bool fortify_seen_p = false;
1681 : 203198 : bool cxx_assert_seen_p = false;
1682 : :
1683 : : /* All command line defines must have the same location. */
1684 : 203198 : cpp_force_token_locations (parse_in, line_table->highest_line);
1685 : 383849 : for (size_t i = 0; i < deferred_count; i++)
1686 : : {
1687 : 180651 : struct deferred_opt *opt = &deferred_opts[i];
1688 : :
1689 : 180651 : if (opt->code == OPT_D)
1690 : 164604 : cpp_define (parse_in, opt->arg);
1691 : 16047 : else if (opt->code == OPT_U)
1692 : 61 : cpp_undef (parse_in, opt->arg);
1693 : 15986 : else if (opt->code == OPT_A)
1694 : : {
1695 : 10 : if (opt->arg[0] == '-')
1696 : 2 : cpp_unassert (parse_in, opt->arg + 1);
1697 : : else
1698 : 8 : cpp_assert (parse_in, opt->arg);
1699 : : }
1700 : :
1701 : 180651 : if (UNLIKELY (flag_hardened)
1702 : 83 : && (opt->code == OPT_D || opt->code == OPT_U))
1703 : : {
1704 : 83 : if (!fortify_seen_p)
1705 : 79 : fortify_seen_p
1706 : 79 : = (!strncmp (opt->arg, "_FORTIFY_SOURCE", 15)
1707 : 79 : && (opt->arg[15] == '\0' || opt->arg[15] == '='));
1708 : 83 : if (!cxx_assert_seen_p)
1709 : 83 : cxx_assert_seen_p
1710 : 83 : = (!strncmp (opt->arg, "_GLIBCXX_ASSERTIONS", 19)
1711 : 83 : && (opt->arg[19] == '\0' || opt->arg[19] == '='));
1712 : : }
1713 : : }
1714 : :
1715 : 203198 : if (flag_hardened)
1716 : : {
1717 : 91 : if (!fortify_seen_p && optimize > 0)
1718 : 71 : cpp_define_formatted (parse_in, "_FORTIFY_SOURCE=%u",
1719 : 71 : targetm.fortify_source_default_level ());
1720 : 20 : else if (optimize == 0)
1721 : 20 : warning_at (UNKNOWN_LOCATION, OPT_Whardened,
1722 : : "%<_FORTIFY_SOURCE%> is not enabled by %<-fhardened%> "
1723 : : "because optimizations are turned off");
1724 : : else
1725 : 0 : warning_at (UNKNOWN_LOCATION, OPT_Whardened,
1726 : : "%<_FORTIFY_SOURCE%> is not enabled by %<-fhardened%> "
1727 : : "because it was specified in %<-D%> or %<-U%>");
1728 : 91 : if (!cxx_assert_seen_p)
1729 : 87 : cpp_define (parse_in, "_GLIBCXX_ASSERTIONS");
1730 : : else
1731 : 4 : warning_at (UNKNOWN_LOCATION, OPT_Whardened,
1732 : : "%<_GLIBCXX_ASSERTIONS%> is not enabled by "
1733 : : "%<-fhardened%> because it was specified in %<-D%> "
1734 : : "or %<-U%>");
1735 : : }
1736 : :
1737 : 203198 : cpp_stop_forcing_token_locations (parse_in);
1738 : : }
1739 : 525 : else if (cpp_opts->directives_only)
1740 : 41 : cpp_init_special_builtins (parse_in);
1741 : :
1742 : : /* Start the main input file, if the debug writer wants it. */
1743 : 203723 : if (debug_hooks->start_end_main_source_file
1744 : 42338 : && !flag_preprocess_only)
1745 : 40165 : (*debug_hooks->start_source_file) (0, this_input_filename);
1746 : :
1747 : 203723 : if (!cpp_opts->preprocessed)
1748 : : /* Handle -imacros after -D and -U. */
1749 : 383849 : for (size_t i = 0; i < deferred_count; i++)
1750 : : {
1751 : 180651 : struct deferred_opt *opt = &deferred_opts[i];
1752 : :
1753 : 180651 : if (opt->code == OPT_imacros
1754 : 180651 : && cpp_push_include (parse_in, opt->arg))
1755 : : {
1756 : : /* Disable push_command_line_include callback for now. */
1757 : 8 : include_cursor = deferred_count + 1;
1758 : 8 : cpp_scan_nooutput (parse_in);
1759 : : }
1760 : : }
1761 : :
1762 : 203723 : include_cursor = 0;
1763 : 203723 : push_command_line_include ();
1764 : 203723 : }
1765 : :
1766 : : /* Give CPP the next file given by -include, if any. */
1767 : : static void
1768 : 723364 : push_command_line_include (void)
1769 : : {
1770 : : /* This can happen if disabled by -imacros for example.
1771 : : Punt so that we don't set "<command-line>" as the filename for
1772 : : the header. */
1773 : 723364 : if (include_cursor > deferred_count)
1774 : : return;
1775 : :
1776 : 416934 : if (!done_preinclude)
1777 : : {
1778 : 203723 : done_preinclude = true;
1779 : 203723 : if (flag_hosted && std_inc && !cpp_opts->preprocessed)
1780 : : {
1781 : 203116 : const char *preinc = targetcm.c_preinclude ();
1782 : 203116 : if (preinc && cpp_push_default_include (parse_in, preinc))
1783 : : return;
1784 : : }
1785 : : }
1786 : :
1787 : 213818 : pch_cpp_save_state ();
1788 : :
1789 : 598243 : while (include_cursor < deferred_count)
1790 : : {
1791 : 180703 : struct deferred_opt *opt = &deferred_opts[include_cursor++];
1792 : :
1793 : 361353 : if (!cpp_opts->preprocessed && opt->code == OPT_include
1794 : 190802 : && cpp_push_include (parse_in, opt->arg))
1795 : : return;
1796 : : }
1797 : :
1798 : 203722 : if (include_cursor == deferred_count)
1799 : : {
1800 : 203722 : include_cursor++;
1801 : : /* -Wunused-macros should only warn about macros defined hereafter. */
1802 : 203722 : cpp_opts->warn_unused_macros = cpp_warn_unused_macros;
1803 : : /* Restore the line map back to the main file. */
1804 : 203722 : if (!cpp_opts->preprocessed)
1805 : : {
1806 : 203197 : cpp_change_file (parse_in, LC_RENAME, this_input_filename);
1807 : 203197 : if (lang_hooks.preprocess_main_file)
1808 : : /* We're starting the main file. Inform the FE of that. */
1809 : 96247 : lang_hooks.preprocess_main_file
1810 : 96247 : (parse_in, line_table, LINEMAPS_LAST_ORDINARY_MAP (line_table));
1811 : : }
1812 : :
1813 : : /* Set this here so the client can change the option if it wishes,
1814 : : and after stacking the main file so we don't trace the main file. */
1815 : 203722 : line_table->trace_includes = cpp_opts->print_include_names;
1816 : : }
1817 : : }
1818 : :
1819 : : /* File change callback. Has to handle -include files. */
1820 : : static void
1821 : 19759377 : cb_file_change (cpp_reader *reader, const line_map_ordinary *new_map)
1822 : : {
1823 : 19759377 : if (flag_preprocess_only)
1824 : 155429 : pp_file_change (new_map);
1825 : : else
1826 : 19603948 : fe_file_change (new_map);
1827 : :
1828 : 19556039 : if (new_map && cpp_opts->preprocessed
1829 : 37876 : && lang_hooks.preprocess_main_file && MAIN_FILE_P (new_map)
1830 : 19761925 : && ORDINARY_MAP_STARTING_LINE_NUMBER (new_map))
1831 : : /* We're starting the main file. Inform the FE of that. */
1832 : 450 : lang_hooks.preprocess_main_file (reader, line_table, new_map);
1833 : :
1834 : 19759377 : if (new_map
1835 : 19556039 : && (new_map->reason == LC_ENTER || new_map->reason == LC_RENAME))
1836 : : {
1837 : : /* Signal to plugins that a file is included. This could happen
1838 : : several times with the same file path, e.g. because of
1839 : : several '#include' or '#line' directives... */
1840 : 10188397 : invoke_plugin_callbacks
1841 : 10188397 : (PLUGIN_INCLUDE_FILE,
1842 : 10188397 : const_cast<char*> (ORDINARY_MAP_FILE_NAME (new_map)));
1843 : : }
1844 : :
1845 : 19556039 : if (new_map == 0 || (new_map->reason == LC_LEAVE && MAIN_FILE_P (new_map)))
1846 : : {
1847 : 519641 : pch_cpp_save_state ();
1848 : 519641 : push_command_line_include ();
1849 : : }
1850 : 19759376 : }
1851 : :
1852 : : void
1853 : 52 : cb_dir_change (cpp_reader * ARG_UNUSED (pfile), const char *dir)
1854 : : {
1855 : 52 : if (!set_src_pwd (dir))
1856 : 0 : warning (0, "too late for # directive to set debug directory");
1857 : 52 : }
1858 : :
1859 : : /* Set the C 89 standard (with 1994 amendments if C94, without GNU
1860 : : extensions if ISO). There is no concept of gnu94. */
1861 : : static void
1862 : 6404 : set_std_c89 (int c94, int iso)
1863 : : {
1864 : 9355 : cpp_set_lang (parse_in, c94 ? CLK_STDC94 : iso ? CLK_STDC89 : CLK_GNUC89);
1865 : 6404 : flag_iso = iso;
1866 : 6404 : flag_no_asm = iso;
1867 : 6404 : flag_no_gnu_keywords = iso;
1868 : 6404 : flag_no_nonansi_builtin = iso;
1869 : 6404 : flag_isoc94 = c94;
1870 : 6404 : flag_isoc99 = 0;
1871 : 6404 : flag_isoc11 = 0;
1872 : 6404 : flag_isoc23 = 0;
1873 : 6404 : flag_isoc2y = 0;
1874 : 6404 : lang_hooks.name = "GNU C89";
1875 : 6404 : }
1876 : :
1877 : : /* Set the C 99 standard (without GNU extensions if ISO). */
1878 : : static void
1879 : 1181 : set_std_c99 (int iso)
1880 : : {
1881 : 1791 : cpp_set_lang (parse_in, iso ? CLK_STDC99 : CLK_GNUC99);
1882 : 1181 : flag_no_asm = iso;
1883 : 1181 : flag_no_nonansi_builtin = iso;
1884 : 1181 : flag_iso = iso;
1885 : 1181 : flag_isoc2y = 0;
1886 : 1181 : flag_isoc23 = 0;
1887 : 1181 : flag_isoc11 = 0;
1888 : 1181 : flag_isoc99 = 1;
1889 : 1181 : flag_isoc94 = 1;
1890 : 1181 : lang_hooks.name = "GNU C99";
1891 : 1181 : }
1892 : :
1893 : : /* Set the C 11 standard (without GNU extensions if ISO). */
1894 : : static void
1895 : 4198 : set_std_c11 (int iso)
1896 : : {
1897 : 7888 : cpp_set_lang (parse_in, iso ? CLK_STDC11 : CLK_GNUC11);
1898 : 4198 : flag_no_asm = iso;
1899 : 4198 : flag_no_nonansi_builtin = iso;
1900 : 4198 : flag_iso = iso;
1901 : 4198 : flag_isoc2y = 0;
1902 : 4198 : flag_isoc23 = 0;
1903 : 4198 : flag_isoc11 = 1;
1904 : 4198 : flag_isoc99 = 1;
1905 : 4198 : flag_isoc94 = 1;
1906 : 4198 : lang_hooks.name = "GNU C11";
1907 : 4198 : }
1908 : :
1909 : : /* Set the C 17 standard (without GNU extensions if ISO). */
1910 : : static void
1911 : 822 : set_std_c17 (int iso)
1912 : : {
1913 : 1606 : cpp_set_lang (parse_in, iso ? CLK_STDC17 : CLK_GNUC17);
1914 : 822 : flag_no_asm = iso;
1915 : 822 : flag_no_nonansi_builtin = iso;
1916 : 822 : flag_iso = iso;
1917 : 822 : flag_isoc2y = 0;
1918 : 822 : flag_isoc23 = 0;
1919 : 822 : flag_isoc11 = 1;
1920 : 822 : flag_isoc99 = 1;
1921 : 822 : flag_isoc94 = 1;
1922 : 822 : lang_hooks.name = "GNU C17";
1923 : 822 : }
1924 : :
1925 : : /* Set the C 23 standard (without GNU extensions if ISO). */
1926 : : static void
1927 : 108494 : set_std_c23 (int iso)
1928 : : {
1929 : 216158 : cpp_set_lang (parse_in, iso ? CLK_STDC23 : CLK_GNUC23);
1930 : 108494 : flag_no_asm = iso;
1931 : 108494 : flag_no_nonansi_builtin = iso;
1932 : 108494 : flag_iso = iso;
1933 : 108494 : flag_isoc2y = 0;
1934 : 108494 : flag_isoc23 = 1;
1935 : 108494 : flag_isoc11 = 1;
1936 : 108494 : flag_isoc99 = 1;
1937 : 108494 : flag_isoc94 = 1;
1938 : 108494 : lang_hooks.name = "GNU C23";
1939 : 108494 : }
1940 : :
1941 : : /* Set the C 2Y standard (without GNU extensions if ISO). */
1942 : : static void
1943 : 154 : set_std_c2y (int iso)
1944 : : {
1945 : 162 : cpp_set_lang (parse_in, iso ? CLK_STDC2Y : CLK_GNUC2Y);
1946 : 154 : flag_no_asm = iso;
1947 : 154 : flag_no_nonansi_builtin = iso;
1948 : 154 : flag_iso = iso;
1949 : 154 : flag_isoc2y = 1;
1950 : 154 : flag_isoc23 = 1;
1951 : 154 : flag_isoc11 = 1;
1952 : 154 : flag_isoc99 = 1;
1953 : 154 : flag_isoc94 = 1;
1954 : 154 : lang_hooks.name = "GNU C2Y";
1955 : 154 : }
1956 : :
1957 : :
1958 : : /* Set the C++ 98 standard (without GNU extensions if ISO). */
1959 : : static void
1960 : 14084 : set_std_cxx98 (int iso)
1961 : : {
1962 : 19398 : cpp_set_lang (parse_in, iso ? CLK_CXX98 : CLK_GNUCXX);
1963 : 14084 : flag_no_gnu_keywords = iso;
1964 : 14084 : flag_no_nonansi_builtin = iso;
1965 : 14084 : flag_iso = iso;
1966 : 14084 : flag_isoc94 = 0;
1967 : 14084 : flag_isoc99 = 0;
1968 : 14084 : cxx_dialect = cxx98;
1969 : 14084 : lang_hooks.name = "GNU C++98";
1970 : 14084 : }
1971 : :
1972 : : /* Set the C++ 2011 standard (without GNU extensions if ISO). */
1973 : : static void
1974 : 5547 : set_std_cxx11 (int iso)
1975 : : {
1976 : 6933 : cpp_set_lang (parse_in, iso ? CLK_CXX11 : CLK_GNUCXX11);
1977 : 5547 : flag_no_gnu_keywords = iso;
1978 : 5547 : flag_no_nonansi_builtin = iso;
1979 : 5547 : flag_iso = iso;
1980 : : /* C++11 includes the C99 standard library. */
1981 : 5547 : flag_isoc94 = 1;
1982 : 5547 : flag_isoc99 = 1;
1983 : 5547 : cxx_dialect = cxx11;
1984 : 5547 : lang_hooks.name = "GNU C++11";
1985 : 5547 : }
1986 : :
1987 : : /* Set the C++ 2014 standard (without GNU extensions if ISO). */
1988 : : static void
1989 : 1244 : set_std_cxx14 (int iso)
1990 : : {
1991 : 1487 : cpp_set_lang (parse_in, iso ? CLK_CXX14 : CLK_GNUCXX14);
1992 : 1244 : flag_no_gnu_keywords = iso;
1993 : 1244 : flag_no_nonansi_builtin = iso;
1994 : 1244 : flag_iso = iso;
1995 : : /* C++14 includes the C99 standard library. */
1996 : 1244 : flag_isoc94 = 1;
1997 : 1244 : flag_isoc99 = 1;
1998 : 1244 : cxx_dialect = cxx14;
1999 : 1244 : lang_hooks.name = "GNU C++14";
2000 : 1244 : }
2001 : :
2002 : : /* Set the C++ 2017 standard (without GNU extensions if ISO). */
2003 : : static void
2004 : 126877 : set_std_cxx17 (int iso)
2005 : : {
2006 : 238054 : cpp_set_lang (parse_in, iso ? CLK_CXX17 : CLK_GNUCXX17);
2007 : 126877 : flag_no_gnu_keywords = iso;
2008 : 126877 : flag_no_nonansi_builtin = iso;
2009 : 126877 : flag_iso = iso;
2010 : : /* C++17 includes the C11 standard library. */
2011 : 126877 : flag_isoc94 = 1;
2012 : 126877 : flag_isoc99 = 1;
2013 : 126877 : flag_isoc11 = 1;
2014 : 126877 : cxx_dialect = cxx17;
2015 : 126877 : lang_hooks.name = "GNU C++17";
2016 : 126877 : }
2017 : :
2018 : : /* Set the C++ 2020 standard (without GNU extensions if ISO). */
2019 : : static void
2020 : 4916 : set_std_cxx20 (int iso)
2021 : : {
2022 : 6303 : cpp_set_lang (parse_in, iso ? CLK_CXX20 : CLK_GNUCXX20);
2023 : 4916 : flag_no_gnu_keywords = iso;
2024 : 4916 : flag_no_nonansi_builtin = iso;
2025 : 4916 : flag_iso = iso;
2026 : : /* C++20 includes the C11 standard library. */
2027 : 4916 : flag_isoc94 = 1;
2028 : 4916 : flag_isoc99 = 1;
2029 : 4916 : flag_isoc11 = 1;
2030 : 4916 : cxx_dialect = cxx20;
2031 : 4916 : lang_hooks.name = "GNU C++20";
2032 : 4916 : }
2033 : :
2034 : : /* Set the C++ 2023 standard (without GNU extensions if ISO). */
2035 : : static void
2036 : 1865 : set_std_cxx23 (int iso)
2037 : : {
2038 : 2332 : cpp_set_lang (parse_in, iso ? CLK_CXX23 : CLK_GNUCXX23);
2039 : 1865 : flag_no_gnu_keywords = iso;
2040 : 1865 : flag_no_nonansi_builtin = iso;
2041 : 1865 : flag_iso = iso;
2042 : : /* C++23 includes the C11 standard library. */
2043 : 1865 : flag_isoc94 = 1;
2044 : 1865 : flag_isoc99 = 1;
2045 : 1865 : flag_isoc11 = 1;
2046 : 1865 : cxx_dialect = cxx23;
2047 : 1865 : lang_hooks.name = "GNU C++23";
2048 : 1865 : }
2049 : :
2050 : : /* Set the C++ 2026 standard (without GNU extensions if ISO). */
2051 : : static void
2052 : 23423 : set_std_cxx26 (int iso)
2053 : : {
2054 : 31057 : cpp_set_lang (parse_in, iso ? CLK_CXX26 : CLK_GNUCXX26);
2055 : 23423 : flag_no_gnu_keywords = iso;
2056 : 23423 : flag_no_nonansi_builtin = iso;
2057 : 23423 : flag_iso = iso;
2058 : : /* C++26 includes the C11 standard library. */
2059 : 23423 : flag_isoc94 = 1;
2060 : 23423 : flag_isoc99 = 1;
2061 : 23423 : flag_isoc11 = 1;
2062 : 23423 : cxx_dialect = cxx26;
2063 : 23423 : lang_hooks.name = "GNU C++26";
2064 : 23423 : }
2065 : :
2066 : : /* Args to -d specify what to dump. Silently ignore
2067 : : unrecognized options; they may be aimed at toplev.cc. */
2068 : : static void
2069 : 1647 : handle_OPT_d (const char *arg)
2070 : : {
2071 : 1647 : char c;
2072 : :
2073 : 3294 : while ((c = *arg++) != '\0')
2074 : 1647 : switch (c)
2075 : : {
2076 : 836 : case 'M': /* Dump macros only. */
2077 : 836 : case 'N': /* Dump names. */
2078 : 836 : case 'D': /* Dump definitions. */
2079 : 836 : case 'U': /* Dump used macros. */
2080 : 836 : flag_dump_macros = c;
2081 : 836 : break;
2082 : :
2083 : 2 : case 'I':
2084 : 2 : flag_dump_includes = 1;
2085 : 2 : break;
2086 : : }
2087 : 1647 : }
|