* Makefile.in (options.c options.h): Use stamp file s-options to
[official-gcc.git] / gcc / c-opts.c
blob2df0a7ea5a7e09f4afbd4963f3653e6b86658139
1 /* C/ObjC/C++ command line option handling.
2 Copyright (C) 2002, 2003, 2004 Free Software Foundation, Inc.
3 Contributed by Neil Booth.
5 This file is part of GCC.
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 2, or (at your option) any later
10 version.
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.
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING. If not, write to the Free
19 Software Foundation, 59 Temple Place - Suite 330, Boston, MA
20 02111-1307, USA. */
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"
41 #ifndef DOLLARS_IN_IDENTIFIERS
42 # define DOLLARS_IN_IDENTIFIERS true
43 #endif
45 #ifndef TARGET_SYSTEM_ROOT
46 # define TARGET_SYSTEM_ROOT NULL
47 #endif
49 static int saved_lineno;
51 /* CPP's options. */
52 static cpp_options *cpp_opts;
54 /* Input filename. */
55 static const char *this_input_filename;
57 /* Filename and stream for preprocessed output. */
58 static const char *out_fname;
59 static FILE *out_stream;
61 /* Append dependencies to deps_file. */
62 static bool deps_append;
64 /* If dependency switches (-MF etc.) have been given. */
65 static bool deps_seen;
67 /* If -v seen. */
68 static bool verbose;
70 /* Dependency output file. */
71 static const char *deps_file;
73 /* The prefix given by -iprefix, if any. */
74 static const char *iprefix;
76 /* The system root, if any. Overridden by -isysroot. */
77 static const char *sysroot = TARGET_SYSTEM_ROOT;
79 /* Zero disables all standard directories for headers. */
80 static bool std_inc = true;
82 /* Zero disables the C++-specific standard directories for headers. */
83 static bool std_cxx_inc = true;
85 /* If the quote chain has been split by -I-. */
86 static bool quote_chain_split;
88 /* If -Wunused-macros. */
89 static bool warn_unused_macros;
91 /* Number of deferred options. */
92 static size_t deferred_count;
94 /* Number of deferred options scanned for -include. */
95 static size_t include_cursor;
97 /* Permit Fotran front-end options. */
98 static bool permit_fortran_options;
100 static void set_Wimplicit (int);
101 static void handle_OPT_d (const char *);
102 static void set_std_cxx98 (int);
103 static void set_std_c89 (int, int);
104 static void set_std_c99 (int);
105 static void check_deps_environment_vars (void);
106 static void handle_deferred_opts (void);
107 static void sanitize_cpp_opts (void);
108 static void add_prefixed_path (const char *, size_t);
109 static void push_command_line_include (void);
110 static void cb_file_change (cpp_reader *, const struct line_map *);
111 static bool finish_options (const char *);
113 #ifndef STDC_0_IN_SYSTEM_HEADERS
114 #define STDC_0_IN_SYSTEM_HEADERS 0
115 #endif
117 /* Holds switches parsed by c_common_handle_option (), but whose
118 handling is deferred to c_common_post_options (). */
119 static void defer_opt (enum opt_code, const char *);
120 static struct deferred_opt
122 enum opt_code code;
123 const char *arg;
124 } *deferred_opts;
126 /* Complain that switch CODE expects an argument but none was
127 provided. OPT was the command-line option. Return FALSE to get
128 the default message in opts.c, TRUE if we provide a specialized
129 one. */
130 bool
131 c_common_missing_argument (const char *opt, size_t code)
133 switch (code)
135 default:
136 /* Pick up the default message. */
137 return false;
139 case OPT_fconstant_string_class_:
140 error ("no class name specified with \"%s\"", opt);
141 break;
143 case OPT_A:
144 error ("assertion missing after \"%s\"", opt);
145 break;
147 case OPT_D:
148 case OPT_U:
149 error ("macro name missing after \"%s\"", opt);
150 break;
152 case OPT_I:
153 case OPT_idirafter:
154 case OPT_isysroot:
155 case OPT_isystem:
156 error ("missing path after \"%s\"", opt);
157 break;
159 case OPT_MF:
160 case OPT_MD:
161 case OPT_MMD:
162 case OPT_include:
163 case OPT_imacros:
164 case OPT_o:
165 error ("missing filename after \"%s\"", opt);
166 break;
168 case OPT_MQ:
169 case OPT_MT:
170 error ("missing makefile target after \"%s\"", opt);
171 break;
174 return true;
177 /* Defer option CODE with argument ARG. */
178 static void
179 defer_opt (enum opt_code code, const char *arg)
181 deferred_opts[deferred_count].code = code;
182 deferred_opts[deferred_count].arg = arg;
183 deferred_count++;
186 /* Common initialization before parsing options. */
187 unsigned int
188 c_common_init_options (unsigned int argc, const char **argv ATTRIBUTE_UNUSED)
190 static const unsigned int lang_flags[] = {CL_C, CL_ObjC, CL_CXX, CL_ObjCXX};
191 unsigned int result;
193 /* This is conditionalized only because that is the way the front
194 ends used to do it. Maybe this should be unconditional? */
195 if (c_dialect_cxx ())
197 /* By default wrap lines at 80 characters. Is getenv
198 ("COLUMNS") preferable? */
199 diagnostic_line_cutoff (global_dc) = 80;
200 /* By default, emit location information once for every
201 diagnostic message. */
202 diagnostic_prefixing_rule (global_dc) = DIAGNOSTICS_SHOW_PREFIX_ONCE;
205 parse_in = cpp_create_reader (c_dialect_cxx () ? CLK_GNUCXX: CLK_GNUC89,
206 ident_hash, &line_table);
208 cpp_opts = cpp_get_options (parse_in);
209 cpp_opts->dollars_in_ident = DOLLARS_IN_IDENTIFIERS;
210 cpp_opts->objc = c_dialect_objc ();
212 /* Reset to avoid warnings on internal definitions. We set it just
213 before passing on command-line options to cpplib. */
214 cpp_opts->warn_dollars = 0;
216 flag_const_strings = c_dialect_cxx ();
217 flag_exceptions = c_dialect_cxx ();
218 warn_pointer_arith = c_dialect_cxx ();
220 deferred_opts = xmalloc (argc * sizeof (struct deferred_opt));
222 result = lang_flags[c_language];
224 /* If potentially preprocessing Fortran we have to accept its front
225 end options since the driver passes most of them through. */
226 #ifdef CL_F77
227 if (c_language == clk_c && argc > 2
228 && !strcmp (argv[2], "-traditional-cpp" ))
230 permit_fortran_options = true;
231 result |= CL_F77;
233 #endif
235 return result;
238 /* Handle switch SCODE with argument ARG. VALUE is true, unless no-
239 form of an -f or -W option was given. Returns 0 if the switch was
240 invalid, a negative number to prevent language-independent
241 processing in toplev.c (a hack necessary for the short-term). */
243 c_common_handle_option (size_t scode, const char *arg, int value)
245 const struct cl_option *option = &cl_options[scode];
246 enum opt_code code = (enum opt_code) scode;
247 int result = 1;
249 switch (code)
251 default:
252 result = permit_fortran_options;
253 break;
255 case OPT__output_pch_:
256 pch_file = arg;
257 break;
259 case OPT_A:
260 defer_opt (code, arg);
261 break;
263 case OPT_C:
264 cpp_opts->discard_comments = 0;
265 break;
267 case OPT_CC:
268 cpp_opts->discard_comments = 0;
269 cpp_opts->discard_comments_in_macro_exp = 0;
270 break;
272 case OPT_D:
273 defer_opt (code, arg);
274 break;
276 case OPT_E:
277 flag_preprocess_only = 1;
278 break;
280 case OPT_H:
281 cpp_opts->print_include_names = 1;
282 break;
284 case OPT_I:
285 if (strcmp (arg, "-"))
286 add_path (xstrdup (arg), BRACKET, 0);
287 else
289 if (quote_chain_split)
290 error ("-I- specified twice");
291 quote_chain_split = true;
292 split_quote_chain ();
294 break;
296 case OPT_M:
297 case OPT_MM:
298 /* When doing dependencies with -M or -MM, suppress normal
299 preprocessed output, but still do -dM etc. as software
300 depends on this. Preprocessed output does occur if -MD, -MMD
301 or environment var dependency generation is used. */
302 cpp_opts->deps.style = (code == OPT_M ? DEPS_SYSTEM: DEPS_USER);
303 flag_no_output = 1;
304 cpp_opts->inhibit_warnings = 1;
305 break;
307 case OPT_MD:
308 case OPT_MMD:
309 cpp_opts->deps.style = (code == OPT_MD ? DEPS_SYSTEM: DEPS_USER);
310 deps_file = arg;
311 break;
313 case OPT_MF:
314 deps_seen = true;
315 deps_file = arg;
316 break;
318 case OPT_MG:
319 deps_seen = true;
320 cpp_opts->deps.missing_files = true;
321 break;
323 case OPT_MP:
324 deps_seen = true;
325 cpp_opts->deps.phony_targets = true;
326 break;
328 case OPT_MQ:
329 case OPT_MT:
330 deps_seen = true;
331 defer_opt (code, arg);
332 break;
334 case OPT_P:
335 flag_no_line_commands = 1;
336 break;
338 case OPT_fworking_directory:
339 flag_working_directory = value;
340 break;
342 case OPT_U:
343 defer_opt (code, arg);
344 break;
346 case OPT_Wabi:
347 warn_abi = value;
348 break;
350 case OPT_Wall:
351 set_Wunused (value);
352 set_Wformat (value);
353 set_Wimplicit (value);
354 warn_char_subscripts = value;
355 warn_missing_braces = value;
356 warn_parentheses = value;
357 warn_return_type = value;
358 warn_sequence_point = value; /* Was C only. */
359 if (c_dialect_cxx ())
360 warn_sign_compare = value;
361 warn_switch = value;
362 warn_strict_aliasing = value;
364 /* Only warn about unknown pragmas that are not in system
365 headers. */
366 warn_unknown_pragmas = value;
368 /* We save the value of warn_uninitialized, since if they put
369 -Wuninitialized on the command line, we need to generate a
370 warning about not using it without also specifying -O. */
371 if (warn_uninitialized != 1)
372 warn_uninitialized = (value ? 2 : 0);
374 if (!c_dialect_cxx ())
375 /* We set this to 2 here, but 1 in -Wmain, so -ffreestanding
376 can turn it off only if it's not explicit. */
377 warn_main = value * 2;
378 else
380 /* C++-specific warnings. */
381 warn_nonvdtor = value;
382 warn_reorder = value;
383 warn_nontemplate_friend = value;
386 cpp_opts->warn_trigraphs = value;
387 cpp_opts->warn_comments = value;
388 cpp_opts->warn_num_sign_change = value;
389 cpp_opts->warn_multichar = value; /* Was C++ only. */
390 break;
392 case OPT_Wbad_function_cast:
393 warn_bad_function_cast = value;
394 break;
396 case OPT_Wcast_qual:
397 warn_cast_qual = value;
398 break;
400 case OPT_Wchar_subscripts:
401 warn_char_subscripts = value;
402 break;
404 case OPT_Wcomment:
405 case OPT_Wcomments:
406 cpp_opts->warn_comments = value;
407 break;
409 case OPT_Wconversion:
410 warn_conversion = value;
411 break;
413 case OPT_Wctor_dtor_privacy:
414 warn_ctor_dtor_privacy = value;
415 break;
417 case OPT_Wdeclaration_after_statement:
418 warn_declaration_after_statement = value;
419 break;
421 case OPT_Wdeprecated:
422 warn_deprecated = value;
423 cpp_opts->warn_deprecated = value;
424 break;
426 case OPT_Wdiv_by_zero:
427 warn_div_by_zero = value;
428 break;
430 case OPT_Weffc__:
431 warn_ecpp = value;
432 break;
434 case OPT_Wendif_labels:
435 cpp_opts->warn_endif_labels = value;
436 break;
438 case OPT_Werror:
439 cpp_opts->warnings_are_errors = value;
440 break;
442 case OPT_Werror_implicit_function_declaration:
443 mesg_implicit_function_declaration = 2;
444 break;
446 case OPT_Wfloat_equal:
447 warn_float_equal = value;
448 break;
450 case OPT_Wformat:
451 set_Wformat (value);
452 break;
454 case OPT_Wformat_:
455 set_Wformat (atoi (arg));
456 break;
458 case OPT_Wformat_extra_args:
459 warn_format_extra_args = value;
460 break;
462 case OPT_Wformat_nonliteral:
463 warn_format_nonliteral = value;
464 break;
466 case OPT_Wformat_security:
467 warn_format_security = value;
468 break;
470 case OPT_Wformat_y2k:
471 warn_format_y2k = value;
472 break;
474 case OPT_Wformat_zero_length:
475 warn_format_zero_length = value;
476 break;
478 case OPT_Winit_self:
479 warn_init_self = value;
480 break;
482 case OPT_Wimplicit:
483 set_Wimplicit (value);
484 break;
486 case OPT_Wimplicit_function_declaration:
487 mesg_implicit_function_declaration = value;
488 break;
490 case OPT_Wimplicit_int:
491 warn_implicit_int = value;
492 break;
494 case OPT_Wimport:
495 /* Silently ignore for now. */
496 break;
498 case OPT_Winvalid_offsetof:
499 warn_invalid_offsetof = value;
500 break;
502 case OPT_Winvalid_pch:
503 cpp_opts->warn_invalid_pch = value;
504 break;
506 case OPT_Wlong_long:
507 warn_long_long = value;
508 break;
510 case OPT_Wmain:
511 if (value)
512 warn_main = 1;
513 else
514 warn_main = -1;
515 break;
517 case OPT_Wmissing_braces:
518 warn_missing_braces = value;
519 break;
521 case OPT_Wmissing_declarations:
522 warn_missing_declarations = value;
523 break;
525 case OPT_Wmissing_format_attribute:
526 warn_missing_format_attribute = value;
527 break;
529 case OPT_Wmissing_prototypes:
530 warn_missing_prototypes = value;
531 break;
533 case OPT_Wmultichar:
534 cpp_opts->warn_multichar = value;
535 break;
537 case OPT_Wnested_externs:
538 warn_nested_externs = value;
539 break;
541 case OPT_Wnon_template_friend:
542 warn_nontemplate_friend = value;
543 break;
545 case OPT_Wnon_virtual_dtor:
546 warn_nonvdtor = value;
547 break;
549 case OPT_Wnonnull:
550 warn_nonnull = value;
551 break;
553 case OPT_Wold_style_definition:
554 warn_old_style_definition = value;
555 break;
557 case OPT_Wold_style_cast:
558 warn_old_style_cast = value;
559 break;
561 case OPT_Woverloaded_virtual:
562 warn_overloaded_virtual = value;
563 break;
565 case OPT_Wparentheses:
566 warn_parentheses = value;
567 break;
569 case OPT_Wpmf_conversions:
570 warn_pmf2ptr = value;
571 break;
573 case OPT_Wpointer_arith:
574 warn_pointer_arith = value;
575 break;
577 case OPT_Wprotocol:
578 warn_protocol = value;
579 break;
581 case OPT_Wselector:
582 warn_selector = value;
583 break;
585 case OPT_Wredundant_decls:
586 warn_redundant_decls = value;
587 break;
589 case OPT_Wreorder:
590 warn_reorder = value;
591 break;
593 case OPT_Wreturn_type:
594 warn_return_type = value;
595 break;
597 case OPT_Wsequence_point:
598 warn_sequence_point = value;
599 break;
601 case OPT_Wsign_compare:
602 warn_sign_compare = value;
603 break;
605 case OPT_Wsign_promo:
606 warn_sign_promo = value;
607 break;
609 case OPT_Wstrict_prototypes:
610 warn_strict_prototypes = value;
611 break;
613 case OPT_Wsynth:
614 warn_synth = value;
615 break;
617 case OPT_Wsystem_headers:
618 cpp_opts->warn_system_headers = value;
619 break;
621 case OPT_Wtraditional:
622 warn_traditional = value;
623 cpp_opts->warn_traditional = value;
624 break;
626 case OPT_Wtrigraphs:
627 cpp_opts->warn_trigraphs = value;
628 break;
630 case OPT_Wundeclared_selector:
631 warn_undeclared_selector = value;
632 break;
634 case OPT_Wundef:
635 cpp_opts->warn_undef = value;
636 break;
638 case OPT_Wunknown_pragmas:
639 /* Set to greater than 1, so that even unknown pragmas in
640 system headers will be warned about. */
641 warn_unknown_pragmas = value * 2;
642 break;
644 case OPT_Wunused_macros:
645 warn_unused_macros = value;
646 break;
648 case OPT_Wwrite_strings:
649 if (!c_dialect_cxx ())
650 flag_const_strings = value;
651 else
652 warn_write_strings = value;
653 break;
655 case OPT_ansi:
656 if (!c_dialect_cxx ())
657 set_std_c89 (false, true);
658 else
659 set_std_cxx98 (true);
660 break;
662 case OPT_d:
663 handle_OPT_d (arg);
664 break;
666 case OPT_fcond_mismatch:
667 if (!c_dialect_cxx ())
669 flag_cond_mismatch = value;
670 break;
672 /* Fall through. */
674 case OPT_fall_virtual:
675 case OPT_falt_external_templates:
676 case OPT_fenum_int_equiv:
677 case OPT_fexternal_templates:
678 case OPT_fguiding_decls:
679 case OPT_fhonor_std:
680 case OPT_fhuge_objects:
681 case OPT_flabels_ok:
682 case OPT_fname_mangling_version_:
683 case OPT_fnew_abi:
684 case OPT_fnonnull_objects:
685 case OPT_fsquangle:
686 case OPT_fstrict_prototype:
687 case OPT_fthis_is_variable:
688 case OPT_fvtable_thunks:
689 case OPT_fxref:
690 case OPT_fvtable_gc:
691 warning ("switch \"%s\" is no longer supported", option->opt_text);
692 break;
694 case OPT_fabi_version_:
695 flag_abi_version = value;
696 break;
698 case OPT_faccess_control:
699 flag_access_control = value;
700 break;
702 case OPT_fasm:
703 flag_no_asm = !value;
704 break;
706 case OPT_fbuiltin:
707 flag_no_builtin = !value;
708 break;
710 case OPT_fbuiltin_:
711 if (value)
712 result = 0;
713 else
714 disable_builtin_function (arg);
715 break;
717 case OPT_fdollars_in_identifiers:
718 cpp_opts->dollars_in_ident = value;
719 break;
721 case OPT_fdump_:
722 if (!dump_switch_p (arg))
723 result = 0;
724 break;
726 case OPT_ffreestanding:
727 value = !value;
728 /* Fall through.... */
729 case OPT_fhosted:
730 flag_hosted = value;
731 flag_no_builtin = !value;
732 /* warn_main will be 2 if set by -Wall, 1 if set by -Wmain */
733 if (!value && warn_main == 2)
734 warn_main = 0;
735 break;
737 case OPT_fshort_double:
738 flag_short_double = value;
739 break;
741 case OPT_fshort_enums:
742 flag_short_enums = value;
743 break;
745 case OPT_fshort_wchar:
746 flag_short_wchar = value;
747 break;
749 case OPT_fsigned_bitfields:
750 flag_signed_bitfields = value;
751 explicit_flag_signed_bitfields = 1;
752 break;
754 case OPT_fsigned_char:
755 flag_signed_char = value;
756 break;
758 case OPT_funsigned_bitfields:
759 flag_signed_bitfields = !value;
760 explicit_flag_signed_bitfields = 1;
761 break;
763 case OPT_funsigned_char:
764 flag_signed_char = !value;
765 break;
767 case OPT_fcheck_new:
768 flag_check_new = value;
769 break;
771 case OPT_fconserve_space:
772 flag_conserve_space = value;
773 break;
775 case OPT_fconst_strings:
776 flag_const_strings = value;
777 break;
779 case OPT_fconstant_string_class_:
780 constant_string_class_name = arg;
781 break;
783 case OPT_fdefault_inline:
784 flag_default_inline = value;
785 break;
787 case OPT_felide_constructors:
788 flag_elide_constructors = value;
789 break;
791 case OPT_fenforce_eh_specs:
792 flag_enforce_eh_specs = value;
793 break;
795 case OPT_ffixed_form:
796 case OPT_ffixed_line_length_:
797 /* Fortran front end options ignored when preprocessing only. */
798 if (!flag_preprocess_only)
799 result = 0;
800 break;
802 case OPT_ffor_scope:
803 flag_new_for_scope = value;
804 break;
806 case OPT_fgnu_keywords:
807 flag_no_gnu_keywords = !value;
808 break;
810 case OPT_fgnu_runtime:
811 flag_next_runtime = !value;
812 break;
814 case OPT_fhandle_exceptions:
815 warning ("-fhandle-exceptions has been renamed -fexceptions (and is now on by default)");
816 flag_exceptions = value;
817 break;
819 case OPT_fimplement_inlines:
820 flag_implement_inlines = value;
821 break;
823 case OPT_fimplicit_inline_templates:
824 flag_implicit_inline_templates = value;
825 break;
827 case OPT_fimplicit_templates:
828 flag_implicit_templates = value;
829 break;
831 case OPT_fms_extensions:
832 flag_ms_extensions = value;
833 break;
835 case OPT_fnext_runtime:
836 flag_next_runtime = value;
837 break;
839 case OPT_fnil_receivers:
840 flag_nil_receivers = value;
841 break;
843 case OPT_fnonansi_builtins:
844 flag_no_nonansi_builtin = !value;
845 break;
847 case OPT_fobjc_exceptions:
848 flag_objc_exceptions = value;
849 break;
851 case OPT_foperator_names:
852 cpp_opts->operator_names = value;
853 break;
855 case OPT_foptional_diags:
856 flag_optional_diags = value;
857 break;
859 case OPT_fpch_deps:
860 cpp_opts->restore_pch_deps = value;
861 break;
863 case OPT_fpermissive:
864 flag_permissive = value;
865 break;
867 case OPT_fpreprocessed:
868 cpp_opts->preprocessed = value;
869 break;
871 case OPT_freplace_objc_classes:
872 flag_replace_objc_classes = value;
873 break;
875 case OPT_frepo:
876 flag_use_repository = value;
877 if (value)
878 flag_implicit_templates = 0;
879 break;
881 case OPT_frtti:
882 flag_rtti = value;
883 break;
885 case OPT_fshow_column:
886 cpp_opts->show_column = value;
887 break;
889 case OPT_fstats:
890 flag_detailed_statistics = value;
891 break;
893 case OPT_ftabstop_:
894 /* It is documented that we silently ignore silly values. */
895 if (value >= 1 && value <= 100)
896 cpp_opts->tabstop = value;
897 break;
899 case OPT_fexec_charset_:
900 cpp_opts->narrow_charset = arg;
901 break;
903 case OPT_fwide_exec_charset_:
904 cpp_opts->wide_charset = arg;
905 break;
907 case OPT_ftemplate_depth_:
908 max_tinst_depth = value;
909 break;
911 case OPT_fuse_cxa_atexit:
912 flag_use_cxa_atexit = value;
913 break;
915 case OPT_fweak:
916 flag_weak = value;
917 break;
919 case OPT_fzero_link:
920 flag_zero_link = value;
921 break;
923 case OPT_gen_decls:
924 flag_gen_declaration = 1;
925 break;
927 case OPT_idirafter:
928 add_path (xstrdup (arg), AFTER, 0);
929 break;
931 case OPT_imacros:
932 case OPT_include:
933 defer_opt (code, arg);
934 break;
936 case OPT_iprefix:
937 iprefix = arg;
938 break;
940 case OPT_isysroot:
941 sysroot = arg;
942 break;
944 case OPT_isystem:
945 add_path (xstrdup (arg), SYSTEM, 0);
946 break;
948 case OPT_iwithprefix:
949 add_prefixed_path (arg, SYSTEM);
950 break;
952 case OPT_iwithprefixbefore:
953 add_prefixed_path (arg, BRACKET);
954 break;
956 case OPT_lang_asm:
957 cpp_set_lang (parse_in, CLK_ASM);
958 cpp_opts->dollars_in_ident = false;
959 break;
961 case OPT_lang_objc:
962 cpp_opts->objc = 1;
963 break;
965 case OPT_nostdinc:
966 std_inc = false;
967 break;
969 case OPT_nostdinc__:
970 std_cxx_inc = false;
971 break;
973 case OPT_o:
974 if (!out_fname)
975 out_fname = arg;
976 else
977 error ("output filename specified twice");
978 break;
980 /* We need to handle the -pedantic switches here, rather than in
981 c_common_post_options, so that a subsequent -Wno-endif-labels
982 is not overridden. */
983 case OPT_pedantic_errors:
984 cpp_opts->pedantic_errors = 1;
985 /* Fall through. */
986 case OPT_pedantic:
987 cpp_opts->pedantic = 1;
988 cpp_opts->warn_endif_labels = 1;
989 break;
991 case OPT_print_objc_runtime_info:
992 print_struct_values = 1;
993 break;
995 case OPT_remap:
996 cpp_opts->remap = 1;
997 break;
999 case OPT_std_c__98:
1000 case OPT_std_gnu__98:
1001 set_std_cxx98 (code == OPT_std_c__98 /* ISO */);
1002 break;
1004 case OPT_std_c89:
1005 case OPT_std_iso9899_1990:
1006 case OPT_std_iso9899_199409:
1007 set_std_c89 (code == OPT_std_iso9899_199409 /* c94 */, true /* ISO */);
1008 break;
1010 case OPT_std_gnu89:
1011 set_std_c89 (false /* c94 */, false /* ISO */);
1012 break;
1014 case OPT_std_c99:
1015 case OPT_std_c9x:
1016 case OPT_std_iso9899_1999:
1017 case OPT_std_iso9899_199x:
1018 set_std_c99 (true /* ISO */);
1019 break;
1021 case OPT_std_gnu99:
1022 case OPT_std_gnu9x:
1023 set_std_c99 (false /* ISO */);
1024 break;
1026 case OPT_trigraphs:
1027 cpp_opts->trigraphs = 1;
1028 break;
1030 case OPT_traditional_cpp:
1031 cpp_opts->traditional = 1;
1032 break;
1034 case OPT_undef:
1035 flag_undef = 1;
1036 break;
1038 case OPT_w:
1039 cpp_opts->inhibit_warnings = 1;
1040 break;
1042 case OPT_v:
1043 verbose = true;
1044 break;
1047 return result;
1050 /* Post-switch processing. */
1051 bool
1052 c_common_post_options (const char **pfilename ATTRIBUTE_UNUSED)
1054 /* Canonicalize the input and output filenames. */
1055 if (in_fnames == NULL)
1057 in_fnames = xmalloc (sizeof (in_fnames[0]));
1058 in_fnames[0] = "";
1060 else if (strcmp (in_fnames[0], "-") == 0)
1061 in_fnames[0] = "";
1063 if (out_fname == NULL || !strcmp (out_fname, "-"))
1064 out_fname = "";
1066 if (cpp_opts->deps.style == DEPS_NONE)
1067 check_deps_environment_vars ();
1069 handle_deferred_opts ();
1071 sanitize_cpp_opts ();
1073 register_include_chains (parse_in, sysroot, iprefix,
1074 std_inc, std_cxx_inc && c_dialect_cxx (), verbose);
1076 flag_inline_trees = 1;
1078 /* Use tree inlining if possible. Function instrumentation is only
1079 done in the RTL level, so we disable tree inlining. */
1080 if (! flag_instrument_function_entry_exit)
1082 if (!flag_no_inline)
1083 flag_no_inline = 1;
1084 if (flag_inline_functions)
1086 flag_inline_trees = 2;
1087 flag_inline_functions = 0;
1091 /* -Wextra implies -Wsign-compare, but not if explicitly
1092 overridden. */
1093 if (warn_sign_compare == -1)
1094 warn_sign_compare = extra_warnings;
1096 /* Special format checking options don't work without -Wformat; warn if
1097 they are used. */
1098 if (warn_format_y2k && !warn_format)
1099 warning ("-Wformat-y2k ignored without -Wformat");
1100 if (warn_format_extra_args && !warn_format)
1101 warning ("-Wformat-extra-args ignored without -Wformat");
1102 if (warn_format_zero_length && !warn_format)
1103 warning ("-Wformat-zero-length ignored without -Wformat");
1104 if (warn_format_nonliteral && !warn_format)
1105 warning ("-Wformat-nonliteral ignored without -Wformat");
1106 if (warn_format_security && !warn_format)
1107 warning ("-Wformat-security ignored without -Wformat");
1108 if (warn_missing_format_attribute && !warn_format)
1109 warning ("-Wmissing-format-attribute ignored without -Wformat");
1111 if (flag_preprocess_only)
1113 /* Open the output now. We must do so even if flag_no_output is
1114 on, because there may be other output than from the actual
1115 preprocessing (e.g. from -dM). */
1116 if (out_fname[0] == '\0')
1117 out_stream = stdout;
1118 else
1119 out_stream = fopen (out_fname, "w");
1121 if (out_stream == NULL)
1123 fatal_error ("opening output file %s: %m", out_fname);
1124 return false;
1127 if (num_in_fnames > 1)
1128 error ("too many filenames given. Type %s --help for usage",
1129 progname);
1131 init_pp_output (out_stream);
1133 else
1135 init_c_lex ();
1137 /* Yuk. WTF is this? I do know ObjC relies on it somewhere. */
1138 input_line = 0;
1141 cpp_get_callbacks (parse_in)->file_change = cb_file_change;
1142 cpp_post_options (parse_in);
1144 saved_lineno = input_line;
1145 input_line = 0;
1147 /* If an error has occurred in cpplib, note it so we fail
1148 immediately. */
1149 errorcount += cpp_errors (parse_in);
1151 return flag_preprocess_only;
1154 /* Front end initialization common to C, ObjC and C++. */
1155 bool
1156 c_common_init (void)
1158 input_line = saved_lineno;
1160 /* Set up preprocessor arithmetic. Must be done after call to
1161 c_common_nodes_and_builtins for type nodes to be good. */
1162 cpp_opts->precision = TYPE_PRECISION (intmax_type_node);
1163 cpp_opts->char_precision = TYPE_PRECISION (char_type_node);
1164 cpp_opts->int_precision = TYPE_PRECISION (integer_type_node);
1165 cpp_opts->wchar_precision = TYPE_PRECISION (wchar_type_node);
1166 cpp_opts->unsigned_wchar = TREE_UNSIGNED (wchar_type_node);
1167 cpp_opts->bytes_big_endian = BYTES_BIG_ENDIAN;
1169 /* This can't happen until after wchar_precision and bytes_big_endian
1170 are known. */
1171 cpp_init_iconv (parse_in);
1173 if (flag_preprocess_only)
1175 if (finish_options (in_fnames[0]))
1176 preprocess_file (parse_in);
1177 return false;
1180 /* Has to wait until now so that cpplib has its hash table. */
1181 init_pragma ();
1183 return true;
1186 /* Initialize the integrated preprocessor after debug output has been
1187 initialized; loop over each input file. */
1188 void
1189 c_common_parse_file (int set_yydebug ATTRIBUTE_UNUSED)
1191 unsigned file_index;
1193 #if YYDEBUG != 0
1194 yydebug = set_yydebug;
1195 #else
1196 warning ("YYDEBUG not defined");
1197 #endif
1199 file_index = 0;
1203 if (file_index > 0)
1205 /* Reset the state of the parser. */
1206 c_reset_state();
1208 /* Reset cpplib's macros and start a new file. */
1209 cpp_undef_all (parse_in);
1212 if (! finish_options(in_fnames[file_index]))
1213 break;
1214 if (file_index == 0)
1215 pch_init();
1216 c_parse_file ();
1218 file_index++;
1219 } while (file_index < num_in_fnames);
1221 free_parser_stacks ();
1222 finish_file ();
1225 /* Common finish hook for the C, ObjC and C++ front ends. */
1226 void
1227 c_common_finish (void)
1229 FILE *deps_stream = NULL;
1231 if (cpp_opts->deps.style != DEPS_NONE)
1233 /* If -M or -MM was seen without -MF, default output to the
1234 output stream. */
1235 if (!deps_file)
1236 deps_stream = out_stream;
1237 else
1239 deps_stream = fopen (deps_file, deps_append ? "a": "w");
1240 if (!deps_stream)
1241 fatal_error ("opening dependency file %s: %m", deps_file);
1245 /* For performance, avoid tearing down cpplib's internal structures
1246 with cpp_destroy (). */
1247 errorcount += cpp_finish (parse_in, deps_stream);
1249 if (deps_stream && deps_stream != out_stream
1250 && (ferror (deps_stream) || fclose (deps_stream)))
1251 fatal_error ("closing dependency file %s: %m", deps_file);
1253 if (out_stream && (ferror (out_stream) || fclose (out_stream)))
1254 fatal_error ("when writing output to %s: %m", out_fname);
1257 /* Either of two environment variables can specify output of
1258 dependencies. Their value is either "OUTPUT_FILE" or "OUTPUT_FILE
1259 DEPS_TARGET", where OUTPUT_FILE is the file to write deps info to
1260 and DEPS_TARGET is the target to mention in the deps. They also
1261 result in dependency information being appended to the output file
1262 rather than overwriting it, and like Sun's compiler
1263 SUNPRO_DEPENDENCIES suppresses the dependency on the main file. */
1264 static void
1265 check_deps_environment_vars (void)
1267 char *spec;
1269 GET_ENVIRONMENT (spec, "DEPENDENCIES_OUTPUT");
1270 if (spec)
1271 cpp_opts->deps.style = DEPS_USER;
1272 else
1274 GET_ENVIRONMENT (spec, "SUNPRO_DEPENDENCIES");
1275 if (spec)
1277 cpp_opts->deps.style = DEPS_SYSTEM;
1278 cpp_opts->deps.ignore_main_file = true;
1282 if (spec)
1284 /* Find the space before the DEPS_TARGET, if there is one. */
1285 char *s = strchr (spec, ' ');
1286 if (s)
1288 /* Let the caller perform MAKE quoting. */
1289 defer_opt (OPT_MT, s + 1);
1290 *s = '\0';
1293 /* Command line -MF overrides environment variables and default. */
1294 if (!deps_file)
1295 deps_file = spec;
1297 deps_append = 1;
1301 /* Handle deferred command line switches. */
1302 static void
1303 handle_deferred_opts (void)
1305 size_t i;
1307 for (i = 0; i < deferred_count; i++)
1309 struct deferred_opt *opt = &deferred_opts[i];
1311 if (opt->code == OPT_MT || opt->code == OPT_MQ)
1312 cpp_add_dependency_target (parse_in, opt->arg, opt->code == OPT_MQ);
1316 /* These settings are appropriate for GCC, but not necessarily so for
1317 cpplib as a library. */
1318 static void
1319 sanitize_cpp_opts (void)
1321 /* If we don't know what style of dependencies to output, complain
1322 if any other dependency switches have been given. */
1323 if (deps_seen && cpp_opts->deps.style == DEPS_NONE)
1324 error ("to generate dependencies you must specify either -M or -MM");
1326 /* -dM and dependencies suppress normal output; do it here so that
1327 the last -d[MDN] switch overrides earlier ones. */
1328 if (flag_dump_macros == 'M')
1329 flag_no_output = 1;
1331 /* Disable -dD, -dN and -dI if normal output is suppressed. Allow
1332 -dM since at least glibc relies on -M -dM to work. */
1333 if (flag_no_output)
1335 if (flag_dump_macros != 'M')
1336 flag_dump_macros = 0;
1337 flag_dump_includes = 0;
1340 cpp_opts->unsigned_char = !flag_signed_char;
1341 cpp_opts->stdc_0_in_system_headers = STDC_0_IN_SYSTEM_HEADERS;
1343 /* We want -Wno-long-long to override -pedantic -std=non-c99
1344 and/or -Wtraditional, whatever the ordering. */
1345 cpp_opts->warn_long_long
1346 = warn_long_long && ((!flag_isoc99 && pedantic) || warn_traditional);
1348 /* If we're generating preprocessor output, emit current directory
1349 if explicitly requested or if debugging information is enabled.
1350 ??? Maybe we should only do it for debugging formats that
1351 actually output the current directory? */
1352 if (flag_working_directory == -1)
1353 flag_working_directory = (debug_info_level != DINFO_LEVEL_NONE);
1354 cpp_opts->working_directory
1355 = flag_preprocess_only && flag_working_directory;
1358 /* Add include path with a prefix at the front of its name. */
1359 static void
1360 add_prefixed_path (const char *suffix, size_t chain)
1362 char *path;
1363 const char *prefix;
1364 size_t prefix_len, suffix_len;
1366 suffix_len = strlen (suffix);
1367 prefix = iprefix ? iprefix : cpp_GCC_INCLUDE_DIR;
1368 prefix_len = iprefix ? strlen (iprefix) : cpp_GCC_INCLUDE_DIR_len;
1370 path = xmalloc (prefix_len + suffix_len + 1);
1371 memcpy (path, prefix, prefix_len);
1372 memcpy (path + prefix_len, suffix, suffix_len);
1373 path[prefix_len + suffix_len] = '\0';
1375 add_path (path, chain, 0);
1378 /* Handle -D, -U, -A, -imacros, and the first -include.
1379 TIF is the input file to which we will return after processing all
1380 the includes. Returns true on success. */
1381 static bool
1382 finish_options (const char *tif)
1384 this_input_filename = tif;
1385 if (! cpp_find_main_file (parse_in, this_input_filename))
1386 return false;
1388 if (!cpp_opts->preprocessed)
1390 size_t i;
1392 cpp_change_file (parse_in, LC_ENTER, _("<built-in>"));
1393 cpp_init_builtins (parse_in, flag_hosted);
1394 c_cpp_builtins (parse_in);
1396 /* We're about to send user input to cpplib, so make it warn for
1397 things that we previously (when we sent it internal definitions)
1398 told it to not warn.
1400 C99 permits implementation-defined characters in identifiers.
1401 The documented meaning of -std= is to turn off extensions that
1402 conflict with the specified standard, and since a strictly
1403 conforming program cannot contain a '$', we do not condition
1404 their acceptance on the -std= setting. */
1405 cpp_opts->warn_dollars = (cpp_opts->pedantic && !cpp_opts->c99);
1407 cpp_change_file (parse_in, LC_RENAME, _("<command line>"));
1408 for (i = 0; i < deferred_count; i++)
1410 struct deferred_opt *opt = &deferred_opts[i];
1412 if (opt->code == OPT_D)
1413 cpp_define (parse_in, opt->arg);
1414 else if (opt->code == OPT_U)
1415 cpp_undef (parse_in, opt->arg);
1416 else if (opt->code == OPT_A)
1418 if (opt->arg[0] == '-')
1419 cpp_unassert (parse_in, opt->arg + 1);
1420 else
1421 cpp_assert (parse_in, opt->arg);
1425 /* Handle -imacros after -D and -U. */
1426 for (i = 0; i < deferred_count; i++)
1428 struct deferred_opt *opt = &deferred_opts[i];
1430 if (opt->code == OPT_imacros
1431 && cpp_push_include (parse_in, opt->arg))
1433 /* Disable push_command_line_include callback for now. */
1434 include_cursor = deferred_count + 1;
1435 cpp_scan_nooutput (parse_in);
1440 include_cursor = 0;
1441 push_command_line_include ();
1442 return true;
1445 /* Give CPP the next file given by -include, if any. */
1446 static void
1447 push_command_line_include (void)
1449 while (include_cursor < deferred_count)
1451 struct deferred_opt *opt = &deferred_opts[include_cursor++];
1453 if (! cpp_opts->preprocessed && opt->code == OPT_include
1454 && cpp_push_include (parse_in, opt->arg))
1455 return;
1458 if (include_cursor == deferred_count)
1460 include_cursor++;
1461 /* Restore the line map from <command line>. */
1462 if (! cpp_opts->preprocessed)
1463 cpp_change_file (parse_in, LC_LEAVE, NULL);
1464 /* -Wunused-macros should only warn about macros defined hereafter. */
1465 cpp_opts->warn_unused_macros = warn_unused_macros;
1466 cpp_push_main_file (parse_in);
1470 /* File change callback. Has to handle -include files. */
1471 static void
1472 cb_file_change (cpp_reader *pfile ATTRIBUTE_UNUSED,
1473 const struct line_map *new_map)
1475 if (flag_preprocess_only)
1476 pp_file_change (new_map);
1477 else
1478 fe_file_change (new_map);
1480 if (new_map == 0 || (new_map->reason == LC_LEAVE && MAIN_FILE_P (new_map)))
1481 push_command_line_include ();
1484 /* Set the C 89 standard (with 1994 amendments if C94, without GNU
1485 extensions if ISO). There is no concept of gnu94. */
1486 static void
1487 set_std_c89 (int c94, int iso)
1489 cpp_set_lang (parse_in, c94 ? CLK_STDC94: iso ? CLK_STDC89: CLK_GNUC89);
1490 flag_iso = iso;
1491 flag_no_asm = iso;
1492 flag_no_gnu_keywords = iso;
1493 flag_no_nonansi_builtin = iso;
1494 flag_isoc94 = c94;
1495 flag_isoc99 = 0;
1496 flag_writable_strings = 0;
1499 /* Set the C 99 standard (without GNU extensions if ISO). */
1500 static void
1501 set_std_c99 (int iso)
1503 cpp_set_lang (parse_in, iso ? CLK_STDC99: CLK_GNUC99);
1504 flag_no_asm = iso;
1505 flag_no_nonansi_builtin = iso;
1506 flag_iso = iso;
1507 flag_isoc99 = 1;
1508 flag_isoc94 = 1;
1509 flag_writable_strings = 0;
1512 /* Set the C++ 98 standard (without GNU extensions if ISO). */
1513 static void
1514 set_std_cxx98 (int iso)
1516 cpp_set_lang (parse_in, iso ? CLK_CXX98: CLK_GNUCXX);
1517 flag_no_gnu_keywords = iso;
1518 flag_no_nonansi_builtin = iso;
1519 flag_iso = iso;
1522 /* Handle setting implicit to ON. */
1523 static void
1524 set_Wimplicit (int on)
1526 warn_implicit = on;
1527 warn_implicit_int = on;
1528 if (on)
1530 if (mesg_implicit_function_declaration != 2)
1531 mesg_implicit_function_declaration = 1;
1533 else
1534 mesg_implicit_function_declaration = 0;
1537 /* Args to -d specify what to dump. Silently ignore
1538 unrecognized options; they may be aimed at toplev.c. */
1539 static void
1540 handle_OPT_d (const char *arg)
1542 char c;
1544 while ((c = *arg++) != '\0')
1545 switch (c)
1547 case 'M': /* Dump macros only. */
1548 case 'N': /* Dump names. */
1549 case 'D': /* Dump definitions. */
1550 flag_dump_macros = c;
1551 break;
1553 case 'I':
1554 flag_dump_includes = 1;
1555 break;