tree-data-ref.c (subscript_dependence_tester_1): Call free_conflict_function.
[gcc.git] / gcc / c-opts.c
1 /* C/ObjC/C++ command line option handling.
2 Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007
3 Free Software Foundation, Inc.
4 Contributed by Neil Booth.
5
6 This file is part of GCC.
7
8 GCC is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 3, or (at your option) any later
11 version.
12
13 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with GCC; see the file COPYING3. If not see
20 <http://www.gnu.org/licenses/>. */
21
22 #include "config.h"
23 #include "system.h"
24 #include "coretypes.h"
25 #include "tm.h"
26 #include "tree.h"
27 #include "c-common.h"
28 #include "c-pragma.h"
29 #include "flags.h"
30 #include "toplev.h"
31 #include "langhooks.h"
32 #include "tree-inline.h"
33 #include "diagnostic.h"
34 #include "intl.h"
35 #include "cppdefault.h"
36 #include "c-incpath.h"
37 #include "debug.h" /* For debug_hooks. */
38 #include "opts.h"
39 #include "options.h"
40 #include "mkdeps.h"
41 #include "target.h"
42 #include "tm_p.h"
43
44 #ifndef DOLLARS_IN_IDENTIFIERS
45 # define DOLLARS_IN_IDENTIFIERS true
46 #endif
47
48 #ifndef TARGET_SYSTEM_ROOT
49 # define TARGET_SYSTEM_ROOT NULL
50 #endif
51
52 #ifndef TARGET_OPTF
53 #define TARGET_OPTF(ARG)
54 #endif
55
56 /* CPP's options. */
57 static cpp_options *cpp_opts;
58
59 /* Input filename. */
60 static const char *this_input_filename;
61
62 /* Filename and stream for preprocessed output. */
63 static const char *out_fname;
64 static FILE *out_stream;
65
66 /* Append dependencies to deps_file. */
67 static bool deps_append;
68
69 /* If dependency switches (-MF etc.) have been given. */
70 static bool deps_seen;
71
72 /* If -v seen. */
73 static bool verbose;
74
75 /* If -lang-fortran seen. */
76 bool lang_fortran = false;
77
78 /* Dependency output file. */
79 static const char *deps_file;
80
81 /* The prefix given by -iprefix, if any. */
82 static const char *iprefix;
83
84 /* The multilib directory given by -imultilib, if any. */
85 static const char *imultilib;
86
87 /* The system root, if any. Overridden by -isysroot. */
88 static const char *sysroot = TARGET_SYSTEM_ROOT;
89
90 /* Zero disables all standard directories for headers. */
91 static bool std_inc = true;
92
93 /* Zero disables the C++-specific standard directories for headers. */
94 static bool std_cxx_inc = true;
95
96 /* If the quote chain has been split by -I-. */
97 static bool quote_chain_split;
98
99 /* If -Wunused-macros. */
100 static bool warn_unused_macros;
101
102 /* If -Wvariadic-macros. */
103 static bool warn_variadic_macros = true;
104
105 /* Number of deferred options. */
106 static size_t deferred_count;
107
108 /* Number of deferred options scanned for -include. */
109 static size_t include_cursor;
110
111 static void set_Wimplicit (int);
112 static void handle_OPT_d (const char *);
113 static void set_std_cxx98 (int);
114 static void set_std_cxx0x (int);
115 static void set_std_c89 (int, int);
116 static void set_std_c99 (int);
117 static void check_deps_environment_vars (void);
118 static void handle_deferred_opts (void);
119 static void sanitize_cpp_opts (void);
120 static void add_prefixed_path (const char *, size_t);
121 static void push_command_line_include (void);
122 static void cb_file_change (cpp_reader *, const struct line_map *);
123 static void cb_dir_change (cpp_reader *, const char *);
124 static void finish_options (void);
125
126 #ifndef STDC_0_IN_SYSTEM_HEADERS
127 #define STDC_0_IN_SYSTEM_HEADERS 0
128 #endif
129
130 /* Holds switches parsed by c_common_handle_option (), but whose
131 handling is deferred to c_common_post_options (). */
132 static void defer_opt (enum opt_code, const char *);
133 static struct deferred_opt
134 {
135 enum opt_code code;
136 const char *arg;
137 } *deferred_opts;
138
139 /* Complain that switch CODE expects an argument but none was
140 provided. OPT was the command-line option. Return FALSE to get
141 the default message in opts.c, TRUE if we provide a specialized
142 one. */
143 bool
144 c_common_missing_argument (const char *opt, size_t code)
145 {
146 switch (code)
147 {
148 default:
149 /* Pick up the default message. */
150 return false;
151
152 case OPT_fconstant_string_class_:
153 error ("no class name specified with %qs", opt);
154 break;
155
156 case OPT_A:
157 error ("assertion missing after %qs", opt);
158 break;
159
160 case OPT_D:
161 case OPT_U:
162 error ("macro name missing after %qs", opt);
163 break;
164
165 case OPT_F:
166 case OPT_I:
167 case OPT_idirafter:
168 case OPT_isysroot:
169 case OPT_isystem:
170 case OPT_iquote:
171 error ("missing path after %qs", opt);
172 break;
173
174 case OPT_MF:
175 case OPT_MD:
176 case OPT_MMD:
177 case OPT_include:
178 case OPT_imacros:
179 case OPT_o:
180 error ("missing filename after %qs", opt);
181 break;
182
183 case OPT_MQ:
184 case OPT_MT:
185 error ("missing makefile target after %qs", opt);
186 break;
187 }
188
189 return true;
190 }
191
192 /* Defer option CODE with argument ARG. */
193 static void
194 defer_opt (enum opt_code code, const char *arg)
195 {
196 deferred_opts[deferred_count].code = code;
197 deferred_opts[deferred_count].arg = arg;
198 deferred_count++;
199 }
200
201 /* Common initialization before parsing options. */
202 unsigned int
203 c_common_init_options (unsigned int argc, const char **argv)
204 {
205 static const unsigned int lang_flags[] = {CL_C, CL_ObjC, CL_CXX, CL_ObjCXX};
206 unsigned int i, result;
207
208 /* This is conditionalized only because that is the way the front
209 ends used to do it. Maybe this should be unconditional? */
210 if (c_dialect_cxx ())
211 {
212 /* By default wrap lines at 80 characters. Is getenv
213 ("COLUMNS") preferable? */
214 diagnostic_line_cutoff (global_dc) = 80;
215 /* By default, emit location information once for every
216 diagnostic message. */
217 diagnostic_prefixing_rule (global_dc) = DIAGNOSTICS_SHOW_PREFIX_ONCE;
218 }
219
220 parse_in = cpp_create_reader (c_dialect_cxx () ? CLK_GNUCXX: CLK_GNUC89,
221 ident_hash, line_table);
222
223 cpp_opts = cpp_get_options (parse_in);
224 cpp_opts->dollars_in_ident = DOLLARS_IN_IDENTIFIERS;
225 cpp_opts->objc = c_dialect_objc ();
226
227 /* Reset to avoid warnings on internal definitions. We set it just
228 before passing on command-line options to cpplib. */
229 cpp_opts->warn_dollars = 0;
230
231 flag_exceptions = c_dialect_cxx ();
232 warn_pointer_arith = c_dialect_cxx ();
233 warn_write_strings = c_dialect_cxx();
234
235 /* By default, C99-like requirements for complex multiply and divide. */
236 flag_complex_method = 2;
237
238 deferred_opts = XNEWVEC (struct deferred_opt, argc);
239
240 result = lang_flags[c_language];
241
242 if (c_language == clk_c)
243 {
244 /* If preprocessing assembly language, accept any of the C-family
245 front end options since the driver may pass them through. */
246 for (i = 1; i < argc; i++)
247 if (! strcmp (argv[i], "-lang-asm"))
248 {
249 result |= CL_C | CL_ObjC | CL_CXX | CL_ObjCXX;
250 break;
251 }
252
253 #ifdef CL_Fortran
254 for (i = 1; i < argc; i++)
255 if (! strcmp (argv[i], "-lang-fortran"))
256 {
257 result |= CL_Fortran;
258 break;
259 }
260 #endif
261 }
262
263 return result;
264 }
265
266 /* Handle switch SCODE with argument ARG. VALUE is true, unless no-
267 form of an -f or -W option was given. Returns 0 if the switch was
268 invalid, a negative number to prevent language-independent
269 processing in toplev.c (a hack necessary for the short-term). */
270 int
271 c_common_handle_option (size_t scode, const char *arg, int value)
272 {
273 const struct cl_option *option = &cl_options[scode];
274 enum opt_code code = (enum opt_code) scode;
275 int result = 1;
276
277 /* Prevent resetting the language standard to a C dialect when the driver
278 has already determined that we're looking at assembler input. */
279 bool preprocessing_asm_p = (cpp_get_options (parse_in)->lang == CLK_ASM);
280
281 switch (code)
282 {
283 default:
284 if (cl_options[code].flags & (CL_C | CL_CXX | CL_ObjC | CL_ObjCXX))
285 {
286 if ((option->flags & CL_TARGET)
287 && ! targetcm.handle_c_option (scode, arg, value))
288 result = 0;
289 break;
290 }
291 #ifdef CL_Fortran
292 if (lang_fortran && (cl_options[code].flags & (CL_Fortran)))
293 break;
294 #endif
295 result = 0;
296 break;
297
298 case OPT__output_pch_:
299 pch_file = arg;
300 break;
301
302 case OPT_A:
303 defer_opt (code, arg);
304 break;
305
306 case OPT_C:
307 cpp_opts->discard_comments = 0;
308 break;
309
310 case OPT_CC:
311 cpp_opts->discard_comments = 0;
312 cpp_opts->discard_comments_in_macro_exp = 0;
313 break;
314
315 case OPT_D:
316 defer_opt (code, arg);
317 break;
318
319 case OPT_E:
320 flag_preprocess_only = 1;
321 break;
322
323 case OPT_H:
324 cpp_opts->print_include_names = 1;
325 break;
326
327 case OPT_F:
328 TARGET_OPTF (xstrdup (arg));
329 break;
330
331 case OPT_I:
332 if (strcmp (arg, "-"))
333 add_path (xstrdup (arg), BRACKET, 0, true);
334 else
335 {
336 if (quote_chain_split)
337 error ("-I- specified twice");
338 quote_chain_split = true;
339 split_quote_chain ();
340 inform ("obsolete option -I- used, please use -iquote instead");
341 }
342 break;
343
344 case OPT_M:
345 case OPT_MM:
346 /* When doing dependencies with -M or -MM, suppress normal
347 preprocessed output, but still do -dM etc. as software
348 depends on this. Preprocessed output does occur if -MD, -MMD
349 or environment var dependency generation is used. */
350 cpp_opts->deps.style = (code == OPT_M ? DEPS_SYSTEM: DEPS_USER);
351 flag_no_output = 1;
352 cpp_opts->inhibit_warnings = 1;
353 break;
354
355 case OPT_MD:
356 case OPT_MMD:
357 cpp_opts->deps.style = (code == OPT_MD ? DEPS_SYSTEM: DEPS_USER);
358 deps_file = arg;
359 break;
360
361 case OPT_MF:
362 deps_seen = true;
363 deps_file = arg;
364 break;
365
366 case OPT_MG:
367 deps_seen = true;
368 cpp_opts->deps.missing_files = true;
369 break;
370
371 case OPT_MP:
372 deps_seen = true;
373 cpp_opts->deps.phony_targets = true;
374 break;
375
376 case OPT_MQ:
377 case OPT_MT:
378 deps_seen = true;
379 defer_opt (code, arg);
380 break;
381
382 case OPT_P:
383 flag_no_line_commands = 1;
384 break;
385
386 case OPT_fworking_directory:
387 flag_working_directory = value;
388 break;
389
390 case OPT_U:
391 defer_opt (code, arg);
392 break;
393
394 case OPT_Wall:
395 set_Wunused (value);
396 set_Wformat (value);
397 set_Wimplicit (value);
398 warn_char_subscripts = value;
399 warn_missing_braces = value;
400 warn_parentheses = value;
401 warn_return_type = value;
402 warn_sequence_point = value; /* Was C only. */
403 warn_switch = value;
404 set_Wstrict_aliasing (value);
405 warn_address = value;
406 warn_strict_overflow = value;
407 warn_array_bounds = value;
408
409 /* Only warn about unknown pragmas that are not in system
410 headers. */
411 warn_unknown_pragmas = value;
412
413 /* We save the value of warn_uninitialized, since if they put
414 -Wuninitialized on the command line, we need to generate a
415 warning about not using it without also specifying -O. */
416 if (warn_uninitialized != 1)
417 warn_uninitialized = (value ? 2 : 0);
418
419 if (!c_dialect_cxx ())
420 /* We set this to 2 here, but 1 in -Wmain, so -ffreestanding
421 can turn it off only if it's not explicit. */
422 warn_main = value * 2;
423 else
424 {
425 /* C++-specific warnings. */
426 warn_sign_compare = value;
427 warn_reorder = value;
428 warn_cxx0x_compat = value;
429 }
430
431 cpp_opts->warn_trigraphs = value;
432 cpp_opts->warn_comments = value;
433 cpp_opts->warn_num_sign_change = value;
434
435 if (warn_pointer_sign == -1)
436 warn_pointer_sign = 1;
437 break;
438
439 case OPT_Wcomment:
440 case OPT_Wcomments:
441 cpp_opts->warn_comments = value;
442 break;
443
444 case OPT_Wdeprecated:
445 cpp_opts->warn_deprecated = value;
446 break;
447
448 case OPT_Wendif_labels:
449 cpp_opts->warn_endif_labels = value;
450 break;
451
452 case OPT_Werror:
453 cpp_opts->warnings_are_errors = value;
454 global_dc->warning_as_error_requested = value;
455 break;
456
457 case OPT_Werror_implicit_function_declaration:
458 /* For backward compatibility, this is the same as
459 -Werror=implicit-function-declaration. */
460 enable_warning_as_error ("implicit-function-declaration", value, CL_C | CL_ObjC);
461 break;
462
463 case OPT_Wformat:
464 set_Wformat (value);
465 break;
466
467 case OPT_Wformat_:
468 set_Wformat (atoi (arg));
469 break;
470
471 case OPT_Wimplicit:
472 set_Wimplicit (value);
473 break;
474
475 case OPT_Wimport:
476 /* Silently ignore for now. */
477 break;
478
479 case OPT_Winvalid_pch:
480 cpp_opts->warn_invalid_pch = value;
481 break;
482
483 case OPT_Wmain:
484 if (value)
485 warn_main = 1;
486 else
487 warn_main = -1;
488 break;
489
490 case OPT_Wmissing_include_dirs:
491 cpp_opts->warn_missing_include_dirs = value;
492 break;
493
494 case OPT_Wmultichar:
495 cpp_opts->warn_multichar = value;
496 break;
497
498 case OPT_Wnormalized_:
499 if (!value || (arg && strcasecmp (arg, "none") == 0))
500 cpp_opts->warn_normalize = normalized_none;
501 else if (!arg || strcasecmp (arg, "nfkc") == 0)
502 cpp_opts->warn_normalize = normalized_KC;
503 else if (strcasecmp (arg, "id") == 0)
504 cpp_opts->warn_normalize = normalized_identifier_C;
505 else if (strcasecmp (arg, "nfc") == 0)
506 cpp_opts->warn_normalize = normalized_C;
507 else
508 error ("argument %qs to %<-Wnormalized%> not recognized", arg);
509 break;
510
511 case OPT_Wreturn_type:
512 warn_return_type = value;
513 break;
514
515 case OPT_Wstrict_null_sentinel:
516 warn_strict_null_sentinel = value;
517 break;
518
519 case OPT_Wsystem_headers:
520 cpp_opts->warn_system_headers = value;
521 break;
522
523 case OPT_Wtraditional:
524 cpp_opts->warn_traditional = value;
525 break;
526
527 case OPT_Wtrigraphs:
528 cpp_opts->warn_trigraphs = value;
529 break;
530
531 case OPT_Wundef:
532 cpp_opts->warn_undef = value;
533 break;
534
535 case OPT_Wunknown_pragmas:
536 /* Set to greater than 1, so that even unknown pragmas in
537 system headers will be warned about. */
538 warn_unknown_pragmas = value * 2;
539 break;
540
541 case OPT_Wunused_macros:
542 warn_unused_macros = value;
543 break;
544
545 case OPT_Wvariadic_macros:
546 warn_variadic_macros = value;
547 break;
548
549 case OPT_Wwrite_strings:
550 warn_write_strings = value;
551 break;
552
553 case OPT_Weffc__:
554 warn_ecpp = value;
555 if (value)
556 warn_nonvdtor = true;
557 break;
558
559 case OPT_ansi:
560 if (!c_dialect_cxx ())
561 set_std_c89 (false, true);
562 else
563 set_std_cxx98 (true);
564 break;
565
566 case OPT_d:
567 handle_OPT_d (arg);
568 break;
569
570 case OPT_fcond_mismatch:
571 if (!c_dialect_cxx ())
572 {
573 flag_cond_mismatch = value;
574 break;
575 }
576 /* Fall through. */
577
578 case OPT_fall_virtual:
579 case OPT_falt_external_templates:
580 case OPT_fenum_int_equiv:
581 case OPT_fexternal_templates:
582 case OPT_fguiding_decls:
583 case OPT_fhonor_std:
584 case OPT_fhuge_objects:
585 case OPT_flabels_ok:
586 case OPT_fname_mangling_version_:
587 case OPT_fnew_abi:
588 case OPT_fnonnull_objects:
589 case OPT_fsquangle:
590 case OPT_fstrict_prototype:
591 case OPT_fthis_is_variable:
592 case OPT_fvtable_thunks:
593 case OPT_fxref:
594 case OPT_fvtable_gc:
595 warning (0, "switch %qs is no longer supported", option->opt_text);
596 break;
597
598 case OPT_faccess_control:
599 flag_access_control = value;
600 break;
601
602 case OPT_fasm:
603 flag_no_asm = !value;
604 break;
605
606 case OPT_fbuiltin:
607 flag_no_builtin = !value;
608 break;
609
610 case OPT_fbuiltin_:
611 if (value)
612 result = 0;
613 else
614 disable_builtin_function (arg);
615 break;
616
617 case OPT_fdirectives_only:
618 cpp_opts->directives_only = value;
619 break;
620
621 case OPT_fdollars_in_identifiers:
622 cpp_opts->dollars_in_ident = value;
623 break;
624
625 case OPT_ffreestanding:
626 value = !value;
627 /* Fall through.... */
628 case OPT_fhosted:
629 flag_hosted = value;
630 flag_no_builtin = !value;
631 /* warn_main will be 2 if set by -Wall, 1 if set by -Wmain */
632 if (!value && warn_main == 2)
633 warn_main = 0;
634 break;
635
636 case OPT_fshort_double:
637 flag_short_double = value;
638 break;
639
640 case OPT_fshort_enums:
641 flag_short_enums = value;
642 break;
643
644 case OPT_fshort_wchar:
645 flag_short_wchar = value;
646 break;
647
648 case OPT_fsigned_bitfields:
649 flag_signed_bitfields = value;
650 break;
651
652 case OPT_fsigned_char:
653 flag_signed_char = value;
654 break;
655
656 case OPT_funsigned_bitfields:
657 flag_signed_bitfields = !value;
658 break;
659
660 case OPT_funsigned_char:
661 flag_signed_char = !value;
662 break;
663
664 case OPT_fcheck_new:
665 flag_check_new = value;
666 break;
667
668 case OPT_fconserve_space:
669 flag_conserve_space = value;
670 break;
671
672 case OPT_fconstant_string_class_:
673 constant_string_class_name = arg;
674 break;
675
676 case OPT_fdefault_inline:
677 flag_default_inline = value;
678 break;
679
680 case OPT_felide_constructors:
681 flag_elide_constructors = value;
682 break;
683
684 case OPT_fenforce_eh_specs:
685 flag_enforce_eh_specs = value;
686 break;
687
688 case OPT_fextended_identifiers:
689 cpp_opts->extended_identifiers = value;
690 break;
691
692 case OPT_ffor_scope:
693 flag_new_for_scope = value;
694 break;
695
696 case OPT_fgnu_keywords:
697 flag_no_gnu_keywords = !value;
698 break;
699
700 case OPT_fgnu_runtime:
701 flag_next_runtime = !value;
702 break;
703
704 case OPT_fhandle_exceptions:
705 warning (0, "-fhandle-exceptions has been renamed -fexceptions (and is now on by default)");
706 flag_exceptions = value;
707 break;
708
709 case OPT_fimplement_inlines:
710 flag_implement_inlines = value;
711 break;
712
713 case OPT_fimplicit_inline_templates:
714 flag_implicit_inline_templates = value;
715 break;
716
717 case OPT_fimplicit_templates:
718 flag_implicit_templates = value;
719 break;
720
721 case OPT_flax_vector_conversions:
722 flag_lax_vector_conversions = value;
723 break;
724
725 case OPT_fms_extensions:
726 flag_ms_extensions = value;
727 break;
728
729 case OPT_fnext_runtime:
730 flag_next_runtime = value;
731 break;
732
733 case OPT_fnil_receivers:
734 flag_nil_receivers = value;
735 break;
736
737 case OPT_fnonansi_builtins:
738 flag_no_nonansi_builtin = !value;
739 break;
740
741 case OPT_foperator_names:
742 cpp_opts->operator_names = value;
743 break;
744
745 case OPT_foptional_diags:
746 flag_optional_diags = value;
747 break;
748
749 case OPT_fpch_deps:
750 cpp_opts->restore_pch_deps = value;
751 break;
752
753 case OPT_fpch_preprocess:
754 flag_pch_preprocess = value;
755 break;
756
757 case OPT_fpermissive:
758 flag_permissive = value;
759 break;
760
761 case OPT_fpreprocessed:
762 cpp_opts->preprocessed = value;
763 break;
764
765 case OPT_freplace_objc_classes:
766 flag_replace_objc_classes = value;
767 break;
768
769 case OPT_frepo:
770 flag_use_repository = value;
771 if (value)
772 flag_implicit_templates = 0;
773 break;
774
775 case OPT_frtti:
776 flag_rtti = value;
777 break;
778
779 case OPT_fshow_column:
780 cpp_opts->show_column = value;
781 break;
782
783 case OPT_fstats:
784 flag_detailed_statistics = value;
785 break;
786
787 case OPT_ftabstop_:
788 /* It is documented that we silently ignore silly values. */
789 if (value >= 1 && value <= 100)
790 cpp_opts->tabstop = value;
791 break;
792
793 case OPT_fexec_charset_:
794 cpp_opts->narrow_charset = arg;
795 break;
796
797 case OPT_fwide_exec_charset_:
798 cpp_opts->wide_charset = arg;
799 break;
800
801 case OPT_finput_charset_:
802 cpp_opts->input_charset = arg;
803 break;
804
805 case OPT_ftemplate_depth_:
806 max_tinst_depth = value;
807 break;
808
809 case OPT_fuse_cxa_atexit:
810 flag_use_cxa_atexit = value;
811 break;
812
813 case OPT_fuse_cxa_get_exception_ptr:
814 flag_use_cxa_get_exception_ptr = value;
815 break;
816
817 case OPT_fvisibility_inlines_hidden:
818 visibility_options.inlines_hidden = value;
819 break;
820
821 case OPT_fweak:
822 flag_weak = value;
823 break;
824
825 case OPT_fthreadsafe_statics:
826 flag_threadsafe_statics = value;
827 break;
828
829 case OPT_fzero_link:
830 flag_zero_link = value;
831 break;
832
833 case OPT_gen_decls:
834 flag_gen_declaration = 1;
835 break;
836
837 case OPT_femit_struct_debug_baseonly:
838 set_struct_debug_option ("base");
839 break;
840
841 case OPT_femit_struct_debug_reduced:
842 set_struct_debug_option ("dir:ord:sys,dir:gen:any,ind:base");
843 break;
844
845 case OPT_femit_struct_debug_detailed_:
846 set_struct_debug_option (arg);
847 break;
848
849 case OPT_idirafter:
850 add_path (xstrdup (arg), AFTER, 0, true);
851 break;
852
853 case OPT_imacros:
854 case OPT_include:
855 defer_opt (code, arg);
856 break;
857
858 case OPT_imultilib:
859 imultilib = arg;
860 break;
861
862 case OPT_iprefix:
863 iprefix = arg;
864 break;
865
866 case OPT_iquote:
867 add_path (xstrdup (arg), QUOTE, 0, true);
868 break;
869
870 case OPT_isysroot:
871 sysroot = arg;
872 break;
873
874 case OPT_isystem:
875 add_path (xstrdup (arg), SYSTEM, 0, true);
876 break;
877
878 case OPT_iwithprefix:
879 add_prefixed_path (arg, SYSTEM);
880 break;
881
882 case OPT_iwithprefixbefore:
883 add_prefixed_path (arg, BRACKET);
884 break;
885
886 case OPT_lang_asm:
887 cpp_set_lang (parse_in, CLK_ASM);
888 cpp_opts->dollars_in_ident = false;
889 break;
890
891 case OPT_lang_fortran:
892 lang_fortran = true;
893 break;
894
895 case OPT_lang_objc:
896 cpp_opts->objc = 1;
897 break;
898
899 case OPT_nostdinc:
900 std_inc = false;
901 break;
902
903 case OPT_nostdinc__:
904 std_cxx_inc = false;
905 break;
906
907 case OPT_o:
908 if (!out_fname)
909 out_fname = arg;
910 else
911 error ("output filename specified twice");
912 break;
913
914 /* We need to handle the -pedantic switches here, rather than in
915 c_common_post_options, so that a subsequent -Wno-endif-labels
916 is not overridden. */
917 case OPT_pedantic_errors:
918 cpp_opts->pedantic_errors = 1;
919 /* Fall through. */
920 case OPT_pedantic:
921 cpp_opts->pedantic = 1;
922 cpp_opts->warn_endif_labels = 1;
923 if (warn_pointer_sign == -1)
924 warn_pointer_sign = 1;
925 if (warn_overlength_strings == -1)
926 warn_overlength_strings = 1;
927 break;
928
929 case OPT_print_objc_runtime_info:
930 print_struct_values = 1;
931 break;
932
933 case OPT_print_pch_checksum:
934 c_common_print_pch_checksum (stdout);
935 exit_after_options = true;
936 break;
937
938 case OPT_remap:
939 cpp_opts->remap = 1;
940 break;
941
942 case OPT_std_c__98:
943 case OPT_std_gnu__98:
944 if (!preprocessing_asm_p)
945 set_std_cxx98 (code == OPT_std_c__98 /* ISO */);
946 break;
947
948 case OPT_std_c__0x:
949 case OPT_std_gnu__0x:
950 if (!preprocessing_asm_p)
951 set_std_cxx0x (code == OPT_std_c__0x /* ISO */);
952 break;
953
954 case OPT_std_c89:
955 case OPT_std_iso9899_1990:
956 case OPT_std_iso9899_199409:
957 if (!preprocessing_asm_p)
958 set_std_c89 (code == OPT_std_iso9899_199409 /* c94 */, true /* ISO */);
959 break;
960
961 case OPT_std_gnu89:
962 if (!preprocessing_asm_p)
963 set_std_c89 (false /* c94 */, false /* ISO */);
964 break;
965
966 case OPT_std_c99:
967 case OPT_std_c9x:
968 case OPT_std_iso9899_1999:
969 case OPT_std_iso9899_199x:
970 if (!preprocessing_asm_p)
971 set_std_c99 (true /* ISO */);
972 break;
973
974 case OPT_std_gnu99:
975 case OPT_std_gnu9x:
976 if (!preprocessing_asm_p)
977 set_std_c99 (false /* ISO */);
978 break;
979
980 case OPT_trigraphs:
981 cpp_opts->trigraphs = 1;
982 break;
983
984 case OPT_traditional_cpp:
985 cpp_opts->traditional = 1;
986 break;
987
988 case OPT_undef:
989 flag_undef = 1;
990 break;
991
992 case OPT_w:
993 cpp_opts->inhibit_warnings = 1;
994 break;
995
996 case OPT_v:
997 verbose = true;
998 break;
999 }
1000
1001 return result;
1002 }
1003
1004 /* Post-switch processing. */
1005 bool
1006 c_common_post_options (const char **pfilename)
1007 {
1008 struct cpp_callbacks *cb;
1009
1010 /* Canonicalize the input and output filenames. */
1011 if (in_fnames == NULL)
1012 {
1013 in_fnames = XNEWVEC (const char *, 1);
1014 in_fnames[0] = "";
1015 }
1016 else if (strcmp (in_fnames[0], "-") == 0)
1017 in_fnames[0] = "";
1018
1019 if (out_fname == NULL || !strcmp (out_fname, "-"))
1020 out_fname = "";
1021
1022 if (cpp_opts->deps.style == DEPS_NONE)
1023 check_deps_environment_vars ();
1024
1025 handle_deferred_opts ();
1026
1027 sanitize_cpp_opts ();
1028
1029 register_include_chains (parse_in, sysroot, iprefix, imultilib,
1030 std_inc, std_cxx_inc && c_dialect_cxx (), verbose);
1031
1032 #ifdef C_COMMON_OVERRIDE_OPTIONS
1033 /* Some machines may reject certain combinations of C
1034 language-specific options. */
1035 C_COMMON_OVERRIDE_OPTIONS;
1036 #endif
1037
1038 flag_inline_trees = 1;
1039
1040 /* Use tree inlining. */
1041 if (!flag_no_inline)
1042 flag_no_inline = 1;
1043 if (flag_inline_functions)
1044 flag_inline_trees = 2;
1045
1046 /* By default we use C99 inline semantics in GNU99 or C99 mode. C99
1047 inline semantics are not supported in GNU89 or C89 mode. */
1048 if (flag_gnu89_inline == -1)
1049 flag_gnu89_inline = !flag_isoc99;
1050 else if (!flag_gnu89_inline && !flag_isoc99)
1051 error ("-fno-gnu89-inline is only supported in GNU99 or C99 mode");
1052
1053 /* If we are given more than one input file, we must use
1054 unit-at-a-time mode. */
1055 if (num_in_fnames > 1)
1056 flag_unit_at_a_time = 1;
1057
1058 /* Default to ObjC sjlj exception handling if NeXT runtime. */
1059 if (flag_objc_sjlj_exceptions < 0)
1060 flag_objc_sjlj_exceptions = flag_next_runtime;
1061 if (flag_objc_exceptions && !flag_objc_sjlj_exceptions)
1062 flag_exceptions = 1;
1063
1064 /* -Wextra implies -Wtype-limits, -Wclobbered,
1065 -Wempty-body, -Wsign-compare,
1066 -Wmissing-field-initializers, -Wmissing-parameter-type
1067 -Wold-style-declaration, -Woverride-init and -Wignored-qualifiers
1068 but not if explicitly overridden. */
1069 if (warn_type_limits == -1)
1070 warn_type_limits = extra_warnings;
1071 if (warn_clobbered == -1)
1072 warn_clobbered = extra_warnings;
1073 if (warn_empty_body == -1)
1074 warn_empty_body = extra_warnings;
1075 if (warn_sign_compare == -1)
1076 warn_sign_compare = extra_warnings;
1077 if (warn_missing_field_initializers == -1)
1078 warn_missing_field_initializers = extra_warnings;
1079 if (warn_missing_parameter_type == -1)
1080 warn_missing_parameter_type = extra_warnings;
1081 if (warn_old_style_declaration == -1)
1082 warn_old_style_declaration = extra_warnings;
1083 if (warn_override_init == -1)
1084 warn_override_init = extra_warnings;
1085 if (warn_ignored_qualifiers == -1)
1086 warn_ignored_qualifiers = extra_warnings;
1087
1088 /* -Wpointer_sign is disabled by default, but it is enabled if any
1089 of -Wall or -pedantic are given. */
1090 if (warn_pointer_sign == -1)
1091 warn_pointer_sign = 0;
1092
1093 /* -Woverlength-strings is off by default, but is enabled by -pedantic.
1094 It is never enabled in C++, as the minimum limit is not normative
1095 in that standard. */
1096 if (warn_overlength_strings == -1 || c_dialect_cxx ())
1097 warn_overlength_strings = 0;
1098
1099 /* Adjust various flags for C++ based on command-line settings. */
1100 if (c_dialect_cxx ())
1101 {
1102 if (!flag_permissive)
1103 {
1104 flag_pedantic_errors = 1;
1105 /* FIXME: For consistency pedantic_errors should have the
1106 same value in the front-end and in CPP. However, this
1107 will break existing applications. The right fix is
1108 disentagle flag_permissive from flag_pedantic_errors,
1109 create a new diagnostic function permerror that is
1110 controlled by flag_permissive and convert most C++
1111 pedwarns to this new function.
1112 cpp_opts->pedantic_errors = 1; */
1113 }
1114 if (!flag_no_inline)
1115 {
1116 flag_inline_trees = 1;
1117 flag_no_inline = 1;
1118 }
1119 if (flag_inline_functions)
1120 flag_inline_trees = 2;
1121 }
1122
1123 /* In C, -Wconversion enables -Wsign-conversion (unless disabled
1124 through -Wno-sign-conversion). While in C++,
1125 -Wsign-conversion needs to be requested explicitly. */
1126 if (warn_sign_conversion == -1)
1127 warn_sign_conversion = (c_dialect_cxx ()) ? 0 : warn_conversion;
1128
1129
1130 /* Special format checking options don't work without -Wformat; warn if
1131 they are used. */
1132 if (!warn_format)
1133 {
1134 warning (OPT_Wformat_y2k,
1135 "-Wformat-y2k ignored without -Wformat");
1136 warning (OPT_Wformat_extra_args,
1137 "-Wformat-extra-args ignored without -Wformat");
1138 warning (OPT_Wformat_zero_length,
1139 "-Wformat-zero-length ignored without -Wformat");
1140 warning (OPT_Wformat_nonliteral,
1141 "-Wformat-nonliteral ignored without -Wformat");
1142 warning (OPT_Wformat_contains_nul,
1143 "-Wformat-contains-nul ignored without -Wformat");
1144 warning (OPT_Wformat_security,
1145 "-Wformat-security ignored without -Wformat");
1146 }
1147
1148 /* -Wimplicit-function-declaration is enabled by default for C99. */
1149 if (warn_implicit_function_declaration == -1)
1150 warn_implicit_function_declaration = flag_isoc99;
1151
1152 /* If we're allowing C++0x constructs, don't warn about C++0x
1153 compatibility problems. */
1154 if (cxx_dialect == cxx0x)
1155 warn_cxx0x_compat = 0;
1156
1157 if (flag_preprocess_only)
1158 {
1159 /* Open the output now. We must do so even if flag_no_output is
1160 on, because there may be other output than from the actual
1161 preprocessing (e.g. from -dM). */
1162 if (out_fname[0] == '\0')
1163 out_stream = stdout;
1164 else
1165 out_stream = fopen (out_fname, "w");
1166
1167 if (out_stream == NULL)
1168 {
1169 fatal_error ("opening output file %s: %m", out_fname);
1170 return false;
1171 }
1172
1173 if (num_in_fnames > 1)
1174 error ("too many filenames given. Type %s --help for usage",
1175 progname);
1176
1177 init_pp_output (out_stream);
1178 }
1179 else
1180 {
1181 init_c_lex ();
1182
1183 /* Yuk. WTF is this? I do know ObjC relies on it somewhere. */
1184 input_location = UNKNOWN_LOCATION;
1185 }
1186
1187 cb = cpp_get_callbacks (parse_in);
1188 cb->file_change = cb_file_change;
1189 cb->dir_change = cb_dir_change;
1190 cpp_post_options (parse_in);
1191
1192 input_location = UNKNOWN_LOCATION;
1193
1194 /* If an error has occurred in cpplib, note it so we fail
1195 immediately. */
1196 errorcount += cpp_errors (parse_in);
1197
1198 *pfilename = this_input_filename
1199 = cpp_read_main_file (parse_in, in_fnames[0]);
1200 /* Don't do any compilation or preprocessing if there is no input file. */
1201 if (this_input_filename == NULL)
1202 {
1203 errorcount++;
1204 return false;
1205 }
1206
1207 if (flag_working_directory
1208 && flag_preprocess_only && !flag_no_line_commands)
1209 pp_dir_change (parse_in, get_src_pwd ());
1210
1211 return flag_preprocess_only;
1212 }
1213
1214 /* Front end initialization common to C, ObjC and C++. */
1215 bool
1216 c_common_init (void)
1217 {
1218 /* Set up preprocessor arithmetic. Must be done after call to
1219 c_common_nodes_and_builtins for type nodes to be good. */
1220 cpp_opts->precision = TYPE_PRECISION (intmax_type_node);
1221 cpp_opts->char_precision = TYPE_PRECISION (char_type_node);
1222 cpp_opts->int_precision = TYPE_PRECISION (integer_type_node);
1223 cpp_opts->wchar_precision = TYPE_PRECISION (wchar_type_node);
1224 cpp_opts->unsigned_wchar = TYPE_UNSIGNED (wchar_type_node);
1225 cpp_opts->bytes_big_endian = BYTES_BIG_ENDIAN;
1226
1227 /* This can't happen until after wchar_precision and bytes_big_endian
1228 are known. */
1229 cpp_init_iconv (parse_in);
1230
1231 if (version_flag)
1232 c_common_print_pch_checksum (stderr);
1233
1234 if (flag_preprocess_only)
1235 {
1236 finish_options ();
1237 preprocess_file (parse_in);
1238 return false;
1239 }
1240
1241 /* Has to wait until now so that cpplib has its hash table. */
1242 init_pragma ();
1243
1244 return true;
1245 }
1246
1247 /* Initialize the integrated preprocessor after debug output has been
1248 initialized; loop over each input file. */
1249 void
1250 c_common_parse_file (int set_yydebug)
1251 {
1252 unsigned int i;
1253
1254 if (set_yydebug)
1255 switch (c_language)
1256 {
1257 case clk_c:
1258 warning(0, "The C parser does not support -dy, option ignored");
1259 break;
1260 case clk_objc:
1261 warning(0,
1262 "The Objective-C parser does not support -dy, option ignored");
1263 break;
1264 case clk_cxx:
1265 warning(0, "The C++ parser does not support -dy, option ignored");
1266 break;
1267 case clk_objcxx:
1268 warning(0,
1269 "The Objective-C++ parser does not support -dy, option ignored");
1270 break;
1271 default:
1272 gcc_unreachable ();
1273 }
1274
1275 i = 0;
1276 for (;;)
1277 {
1278 /* Start the main input file, if the debug writer wants it. */
1279 if (debug_hooks->start_end_main_source_file)
1280 (*debug_hooks->start_source_file) (0, this_input_filename);
1281 finish_options ();
1282 pch_init ();
1283 push_file_scope ();
1284 c_parse_file ();
1285 finish_file ();
1286 pop_file_scope ();
1287 /* And end the main input file, if the debug writer wants it */
1288 if (debug_hooks->start_end_main_source_file)
1289 (*debug_hooks->end_source_file) (0);
1290 if (++i >= num_in_fnames)
1291 break;
1292 cpp_undef_all (parse_in);
1293 cpp_clear_file_cache (parse_in);
1294 this_input_filename
1295 = cpp_read_main_file (parse_in, in_fnames[i]);
1296 /* If an input file is missing, abandon further compilation.
1297 cpplib has issued a diagnostic. */
1298 if (!this_input_filename)
1299 break;
1300 }
1301 }
1302
1303 /* Common finish hook for the C, ObjC and C++ front ends. */
1304 void
1305 c_common_finish (void)
1306 {
1307 FILE *deps_stream = NULL;
1308
1309 if (cpp_opts->deps.style != DEPS_NONE)
1310 {
1311 /* If -M or -MM was seen without -MF, default output to the
1312 output stream. */
1313 if (!deps_file)
1314 deps_stream = out_stream;
1315 else
1316 {
1317 deps_stream = fopen (deps_file, deps_append ? "a": "w");
1318 if (!deps_stream)
1319 fatal_error ("opening dependency file %s: %m", deps_file);
1320 }
1321 }
1322
1323 /* For performance, avoid tearing down cpplib's internal structures
1324 with cpp_destroy (). */
1325 errorcount += cpp_finish (parse_in, deps_stream);
1326
1327 if (deps_stream && deps_stream != out_stream
1328 && (ferror (deps_stream) || fclose (deps_stream)))
1329 fatal_error ("closing dependency file %s: %m", deps_file);
1330
1331 if (out_stream && (ferror (out_stream) || fclose (out_stream)))
1332 fatal_error ("when writing output to %s: %m", out_fname);
1333 }
1334
1335 /* Either of two environment variables can specify output of
1336 dependencies. Their value is either "OUTPUT_FILE" or "OUTPUT_FILE
1337 DEPS_TARGET", where OUTPUT_FILE is the file to write deps info to
1338 and DEPS_TARGET is the target to mention in the deps. They also
1339 result in dependency information being appended to the output file
1340 rather than overwriting it, and like Sun's compiler
1341 SUNPRO_DEPENDENCIES suppresses the dependency on the main file. */
1342 static void
1343 check_deps_environment_vars (void)
1344 {
1345 char *spec;
1346
1347 GET_ENVIRONMENT (spec, "DEPENDENCIES_OUTPUT");
1348 if (spec)
1349 cpp_opts->deps.style = DEPS_USER;
1350 else
1351 {
1352 GET_ENVIRONMENT (spec, "SUNPRO_DEPENDENCIES");
1353 if (spec)
1354 {
1355 cpp_opts->deps.style = DEPS_SYSTEM;
1356 cpp_opts->deps.ignore_main_file = true;
1357 }
1358 }
1359
1360 if (spec)
1361 {
1362 /* Find the space before the DEPS_TARGET, if there is one. */
1363 char *s = strchr (spec, ' ');
1364 if (s)
1365 {
1366 /* Let the caller perform MAKE quoting. */
1367 defer_opt (OPT_MT, s + 1);
1368 *s = '\0';
1369 }
1370
1371 /* Command line -MF overrides environment variables and default. */
1372 if (!deps_file)
1373 deps_file = spec;
1374
1375 deps_append = 1;
1376 deps_seen = true;
1377 }
1378 }
1379
1380 /* Handle deferred command line switches. */
1381 static void
1382 handle_deferred_opts (void)
1383 {
1384 size_t i;
1385 struct deps *deps;
1386
1387 /* Avoid allocating the deps buffer if we don't need it.
1388 (This flag may be true without there having been -MT or -MQ
1389 options, but we'll still need the deps buffer.) */
1390 if (!deps_seen)
1391 return;
1392
1393 deps = cpp_get_deps (parse_in);
1394
1395 for (i = 0; i < deferred_count; i++)
1396 {
1397 struct deferred_opt *opt = &deferred_opts[i];
1398
1399 if (opt->code == OPT_MT || opt->code == OPT_MQ)
1400 deps_add_target (deps, opt->arg, opt->code == OPT_MQ);
1401 }
1402 }
1403
1404 /* These settings are appropriate for GCC, but not necessarily so for
1405 cpplib as a library. */
1406 static void
1407 sanitize_cpp_opts (void)
1408 {
1409 /* If we don't know what style of dependencies to output, complain
1410 if any other dependency switches have been given. */
1411 if (deps_seen && cpp_opts->deps.style == DEPS_NONE)
1412 error ("to generate dependencies you must specify either -M or -MM");
1413
1414 /* -dM and dependencies suppress normal output; do it here so that
1415 the last -d[MDN] switch overrides earlier ones. */
1416 if (flag_dump_macros == 'M')
1417 flag_no_output = 1;
1418
1419 /* By default, -fdirectives-only implies -dD. This allows subsequent phases
1420 to perform proper macro expansion. */
1421 if (cpp_opts->directives_only && !cpp_opts->preprocessed && !flag_dump_macros)
1422 flag_dump_macros = 'D';
1423
1424 /* Disable -dD, -dN and -dI if normal output is suppressed. Allow
1425 -dM since at least glibc relies on -M -dM to work. */
1426 /* Also, flag_no_output implies flag_no_line_commands, always. */
1427 if (flag_no_output)
1428 {
1429 if (flag_dump_macros != 'M')
1430 flag_dump_macros = 0;
1431 flag_dump_includes = 0;
1432 flag_no_line_commands = 1;
1433 }
1434
1435 cpp_opts->unsigned_char = !flag_signed_char;
1436 cpp_opts->stdc_0_in_system_headers = STDC_0_IN_SYSTEM_HEADERS;
1437
1438 /* We want -Wno-long-long to override -pedantic -std=non-c99
1439 and/or -Wtraditional, whatever the ordering. */
1440 cpp_opts->warn_long_long
1441 = warn_long_long && ((pedantic
1442 && (c_dialect_cxx ()
1443 ? cxx_dialect == cxx98
1444 : !flag_isoc99))
1445 || warn_traditional);
1446
1447 /* Similarly with -Wno-variadic-macros. No check for c99 here, since
1448 this also turns off warnings about GCCs extension. */
1449 cpp_opts->warn_variadic_macros
1450 = warn_variadic_macros && (pedantic || warn_traditional);
1451
1452 /* If we're generating preprocessor output, emit current directory
1453 if explicitly requested or if debugging information is enabled.
1454 ??? Maybe we should only do it for debugging formats that
1455 actually output the current directory? */
1456 if (flag_working_directory == -1)
1457 flag_working_directory = (debug_info_level != DINFO_LEVEL_NONE);
1458
1459 if (cpp_opts->directives_only)
1460 {
1461 if (warn_unused_macros)
1462 error ("-fdirectives-only is incompatible with -Wunused_macros");
1463 if (cpp_opts->traditional)
1464 error ("-fdirectives-only is incompatible with -traditional");
1465 }
1466 }
1467
1468 /* Add include path with a prefix at the front of its name. */
1469 static void
1470 add_prefixed_path (const char *suffix, size_t chain)
1471 {
1472 char *path;
1473 const char *prefix;
1474 size_t prefix_len, suffix_len;
1475
1476 suffix_len = strlen (suffix);
1477 prefix = iprefix ? iprefix : cpp_GCC_INCLUDE_DIR;
1478 prefix_len = iprefix ? strlen (iprefix) : cpp_GCC_INCLUDE_DIR_len;
1479
1480 path = (char *) xmalloc (prefix_len + suffix_len + 1);
1481 memcpy (path, prefix, prefix_len);
1482 memcpy (path + prefix_len, suffix, suffix_len);
1483 path[prefix_len + suffix_len] = '\0';
1484
1485 add_path (path, chain, 0, false);
1486 }
1487
1488 /* Handle -D, -U, -A, -imacros, and the first -include. */
1489 static void
1490 finish_options (void)
1491 {
1492 if (!cpp_opts->preprocessed)
1493 {
1494 size_t i;
1495
1496 cb_file_change (parse_in,
1497 linemap_add (line_table, LC_RENAME, 0,
1498 _("<built-in>"), 0));
1499
1500 cpp_init_builtins (parse_in, flag_hosted);
1501 c_cpp_builtins (parse_in);
1502
1503 /* We're about to send user input to cpplib, so make it warn for
1504 things that we previously (when we sent it internal definitions)
1505 told it to not warn.
1506
1507 C99 permits implementation-defined characters in identifiers.
1508 The documented meaning of -std= is to turn off extensions that
1509 conflict with the specified standard, and since a strictly
1510 conforming program cannot contain a '$', we do not condition
1511 their acceptance on the -std= setting. */
1512 cpp_opts->warn_dollars = (cpp_opts->pedantic && !cpp_opts->c99);
1513
1514 cb_file_change (parse_in,
1515 linemap_add (line_table, LC_RENAME, 0,
1516 _("<command-line>"), 0));
1517
1518 for (i = 0; i < deferred_count; i++)
1519 {
1520 struct deferred_opt *opt = &deferred_opts[i];
1521
1522 if (opt->code == OPT_D)
1523 cpp_define (parse_in, opt->arg);
1524 else if (opt->code == OPT_U)
1525 cpp_undef (parse_in, opt->arg);
1526 else if (opt->code == OPT_A)
1527 {
1528 if (opt->arg[0] == '-')
1529 cpp_unassert (parse_in, opt->arg + 1);
1530 else
1531 cpp_assert (parse_in, opt->arg);
1532 }
1533 }
1534
1535 /* Handle -imacros after -D and -U. */
1536 for (i = 0; i < deferred_count; i++)
1537 {
1538 struct deferred_opt *opt = &deferred_opts[i];
1539
1540 if (opt->code == OPT_imacros
1541 && cpp_push_include (parse_in, opt->arg))
1542 {
1543 /* Disable push_command_line_include callback for now. */
1544 include_cursor = deferred_count + 1;
1545 cpp_scan_nooutput (parse_in);
1546 }
1547 }
1548 }
1549 else if (cpp_opts->directives_only)
1550 cpp_init_special_builtins (parse_in);
1551
1552 include_cursor = 0;
1553 push_command_line_include ();
1554 }
1555
1556 /* Give CPP the next file given by -include, if any. */
1557 static void
1558 push_command_line_include (void)
1559 {
1560 while (include_cursor < deferred_count)
1561 {
1562 struct deferred_opt *opt = &deferred_opts[include_cursor++];
1563
1564 if (!cpp_opts->preprocessed && opt->code == OPT_include
1565 && cpp_push_include (parse_in, opt->arg))
1566 return;
1567 }
1568
1569 if (include_cursor == deferred_count)
1570 {
1571 include_cursor++;
1572 /* -Wunused-macros should only warn about macros defined hereafter. */
1573 cpp_opts->warn_unused_macros = warn_unused_macros;
1574 /* Restore the line map from <command line>. */
1575 if (!cpp_opts->preprocessed)
1576 cpp_change_file (parse_in, LC_RENAME, this_input_filename);
1577
1578 /* Set this here so the client can change the option if it wishes,
1579 and after stacking the main file so we don't trace the main file. */
1580 line_table->trace_includes = cpp_opts->print_include_names;
1581 }
1582 }
1583
1584 /* File change callback. Has to handle -include files. */
1585 static void
1586 cb_file_change (cpp_reader * ARG_UNUSED (pfile),
1587 const struct line_map *new_map)
1588 {
1589 if (flag_preprocess_only)
1590 pp_file_change (new_map);
1591 else
1592 fe_file_change (new_map);
1593
1594 if (new_map == 0 || (new_map->reason == LC_LEAVE && MAIN_FILE_P (new_map)))
1595 push_command_line_include ();
1596 }
1597
1598 void
1599 cb_dir_change (cpp_reader * ARG_UNUSED (pfile), const char *dir)
1600 {
1601 if (!set_src_pwd (dir))
1602 warning (0, "too late for # directive to set debug directory");
1603 }
1604
1605 /* Set the C 89 standard (with 1994 amendments if C94, without GNU
1606 extensions if ISO). There is no concept of gnu94. */
1607 static void
1608 set_std_c89 (int c94, int iso)
1609 {
1610 cpp_set_lang (parse_in, c94 ? CLK_STDC94: iso ? CLK_STDC89: CLK_GNUC89);
1611 flag_iso = iso;
1612 flag_no_asm = iso;
1613 flag_no_gnu_keywords = iso;
1614 flag_no_nonansi_builtin = iso;
1615 flag_isoc94 = c94;
1616 flag_isoc99 = 0;
1617 }
1618
1619 /* Set the C 99 standard (without GNU extensions if ISO). */
1620 static void
1621 set_std_c99 (int iso)
1622 {
1623 cpp_set_lang (parse_in, iso ? CLK_STDC99: CLK_GNUC99);
1624 flag_no_asm = iso;
1625 flag_no_nonansi_builtin = iso;
1626 flag_iso = iso;
1627 flag_isoc99 = 1;
1628 flag_isoc94 = 1;
1629 }
1630
1631 /* Set the C++ 98 standard (without GNU extensions if ISO). */
1632 static void
1633 set_std_cxx98 (int iso)
1634 {
1635 cpp_set_lang (parse_in, iso ? CLK_CXX98: CLK_GNUCXX);
1636 flag_no_gnu_keywords = iso;
1637 flag_no_nonansi_builtin = iso;
1638 flag_iso = iso;
1639 cxx_dialect = cxx98;
1640 }
1641
1642 /* Set the C++ 0x working draft "standard" (without GNU extensions if ISO). */
1643 static void
1644 set_std_cxx0x (int iso)
1645 {
1646 cpp_set_lang (parse_in, iso ? CLK_CXX0X: CLK_GNUCXX0X);
1647 flag_no_gnu_keywords = iso;
1648 flag_no_nonansi_builtin = iso;
1649 flag_iso = iso;
1650 cxx_dialect = cxx0x;
1651 }
1652
1653 /* Handle setting implicit to ON. */
1654 static void
1655 set_Wimplicit (int on)
1656 {
1657 warn_implicit = on;
1658 warn_implicit_int = on;
1659 warn_implicit_function_declaration = on;
1660 }
1661
1662 /* Args to -d specify what to dump. Silently ignore
1663 unrecognized options; they may be aimed at toplev.c. */
1664 static void
1665 handle_OPT_d (const char *arg)
1666 {
1667 char c;
1668
1669 while ((c = *arg++) != '\0')
1670 switch (c)
1671 {
1672 case 'M': /* Dump macros only. */
1673 case 'N': /* Dump names. */
1674 case 'D': /* Dump definitions. */
1675 flag_dump_macros = c;
1676 break;
1677
1678 case 'I':
1679 flag_dump_includes = 1;
1680 break;
1681 }
1682 }