Merge from mainline (gomp-merge-2005-02-26).
[official-gcc.git] / gcc / c-opts.c
blob575ff4d485b72cc0754097f1be94ff36309f0510
1 /* C/ObjC/C++ command line option handling.
2 Copyright (C) 2002, 2003, 2004, 2005 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"
40 #include "mkdeps.h"
42 #ifndef DOLLARS_IN_IDENTIFIERS
43 # define DOLLARS_IN_IDENTIFIERS true
44 #endif
46 #ifndef TARGET_SYSTEM_ROOT
47 # define TARGET_SYSTEM_ROOT NULL
48 #endif
50 #ifndef TARGET_OPTF
51 #define TARGET_OPTF(ARG)
52 #endif
54 /* CPP's options. */
55 static cpp_options *cpp_opts;
57 /* Input filename. */
58 static const char *this_input_filename;
60 /* Filename and stream for preprocessed output. */
61 static const char *out_fname;
62 static FILE *out_stream;
64 /* Append dependencies to deps_file. */
65 static bool deps_append;
67 /* If dependency switches (-MF etc.) have been given. */
68 static bool deps_seen;
70 /* If -v seen. */
71 static bool verbose;
73 /* Dependency output file. */
74 static const char *deps_file;
76 /* The prefix given by -iprefix, if any. */
77 static const char *iprefix;
79 /* The system root, if any. Overridden by -isysroot. */
80 static const char *sysroot = TARGET_SYSTEM_ROOT;
82 /* Zero disables all standard directories for headers. */
83 static bool std_inc = true;
85 /* Zero disables the C++-specific standard directories for headers. */
86 static bool std_cxx_inc = true;
88 /* If the quote chain has been split by -I-. */
89 static bool quote_chain_split;
91 /* If -Wunused-macros. */
92 static bool warn_unused_macros;
94 /* If -Wvariadic-macros. */
95 static bool warn_variadic_macros = true;
97 /* Number of deferred options. */
98 static size_t deferred_count;
100 /* Number of deferred options scanned for -include. */
101 static size_t include_cursor;
103 static void set_Wimplicit (int);
104 static void handle_OPT_d (const char *);
105 static void set_std_cxx98 (int);
106 static void set_std_c89 (int, int);
107 static void set_std_c99 (int);
108 static void check_deps_environment_vars (void);
109 static void handle_deferred_opts (void);
110 static void sanitize_cpp_opts (void);
111 static void add_prefixed_path (const char *, size_t);
112 static void push_command_line_include (void);
113 static void cb_file_change (cpp_reader *, const struct line_map *);
114 static void cb_dir_change (cpp_reader *, const char *);
115 static void finish_options (void);
117 #ifndef STDC_0_IN_SYSTEM_HEADERS
118 #define STDC_0_IN_SYSTEM_HEADERS 0
119 #endif
121 /* Holds switches parsed by c_common_handle_option (), but whose
122 handling is deferred to c_common_post_options (). */
123 static void defer_opt (enum opt_code, const char *);
124 static struct deferred_opt
126 enum opt_code code;
127 const char *arg;
128 } *deferred_opts;
130 /* Complain that switch CODE expects an argument but none was
131 provided. OPT was the command-line option. Return FALSE to get
132 the default message in opts.c, TRUE if we provide a specialized
133 one. */
134 bool
135 c_common_missing_argument (const char *opt, size_t code)
137 switch (code)
139 default:
140 /* Pick up the default message. */
141 return false;
143 case OPT_fconstant_string_class_:
144 error ("no class name specified with %qs", opt);
145 break;
147 case OPT_A:
148 error ("assertion missing after %qs", opt);
149 break;
151 case OPT_D:
152 case OPT_U:
153 error ("macro name missing after %qs", opt);
154 break;
156 case OPT_F:
157 case OPT_I:
158 case OPT_idirafter:
159 case OPT_isysroot:
160 case OPT_isystem:
161 case OPT_iquote:
162 error ("missing path after %qs", opt);
163 break;
165 case OPT_MF:
166 case OPT_MD:
167 case OPT_MMD:
168 case OPT_include:
169 case OPT_imacros:
170 case OPT_o:
171 error ("missing filename after %qs", opt);
172 break;
174 case OPT_MQ:
175 case OPT_MT:
176 error ("missing makefile target after %qs", opt);
177 break;
180 return true;
183 /* Defer option CODE with argument ARG. */
184 static void
185 defer_opt (enum opt_code code, const char *arg)
187 deferred_opts[deferred_count].code = code;
188 deferred_opts[deferred_count].arg = arg;
189 deferred_count++;
192 /* Common initialization before parsing options. */
193 unsigned int
194 c_common_init_options (unsigned int argc, const char **argv)
196 static const unsigned int lang_flags[] = {CL_C, CL_ObjC, CL_CXX, CL_ObjCXX};
197 unsigned int i, result;
199 /* This is conditionalized only because that is the way the front
200 ends used to do it. Maybe this should be unconditional? */
201 if (c_dialect_cxx ())
203 /* By default wrap lines at 80 characters. Is getenv
204 ("COLUMNS") preferable? */
205 diagnostic_line_cutoff (global_dc) = 80;
206 /* By default, emit location information once for every
207 diagnostic message. */
208 diagnostic_prefixing_rule (global_dc) = DIAGNOSTICS_SHOW_PREFIX_ONCE;
211 parse_in = cpp_create_reader (c_dialect_cxx () ? CLK_GNUCXX: CLK_GNUC89,
212 ident_hash, &line_table);
214 cpp_opts = cpp_get_options (parse_in);
215 cpp_opts->dollars_in_ident = DOLLARS_IN_IDENTIFIERS;
216 cpp_opts->objc = c_dialect_objc ();
218 /* Reset to avoid warnings on internal definitions. We set it just
219 before passing on command-line options to cpplib. */
220 cpp_opts->warn_dollars = 0;
222 flag_const_strings = c_dialect_cxx ();
223 flag_exceptions = c_dialect_cxx ();
224 warn_pointer_arith = c_dialect_cxx ();
226 deferred_opts = XNEWVEC (struct deferred_opt, argc);
228 result = lang_flags[c_language];
230 if (c_language == clk_c)
232 /* If preprocessing assembly language, accept any of the C-family
233 front end options since the driver may pass them through. */
234 for (i = 1; i < argc; i++)
235 if (! strcmp (argv[i], "-lang-asm"))
237 result |= CL_C | CL_ObjC | CL_CXX | CL_ObjCXX;
238 break;
242 return result;
245 /* Handle switch SCODE with argument ARG. VALUE is true, unless no-
246 form of an -f or -W option was given. Returns 0 if the switch was
247 invalid, a negative number to prevent language-independent
248 processing in toplev.c (a hack necessary for the short-term). */
250 c_common_handle_option (size_t scode, const char *arg, int value)
252 const struct cl_option *option = &cl_options[scode];
253 enum opt_code code = (enum opt_code) scode;
254 int result = 1;
256 switch (code)
258 default:
259 if (cl_options[code].flags & (CL_C | CL_CXX | CL_ObjC | CL_ObjCXX))
260 break;
261 result = 0;
262 break;
264 case OPT__output_pch_:
265 pch_file = arg;
266 break;
268 case OPT_A:
269 defer_opt (code, arg);
270 break;
272 case OPT_C:
273 cpp_opts->discard_comments = 0;
274 break;
276 case OPT_CC:
277 cpp_opts->discard_comments = 0;
278 cpp_opts->discard_comments_in_macro_exp = 0;
279 break;
281 case OPT_D:
282 defer_opt (code, arg);
283 break;
285 case OPT_E:
286 flag_preprocess_only = 1;
287 break;
289 case OPT_H:
290 cpp_opts->print_include_names = 1;
291 break;
293 case OPT_F:
294 TARGET_OPTF (xstrdup (arg));
295 break;
297 case OPT_I:
298 if (strcmp (arg, "-"))
299 add_path (xstrdup (arg), BRACKET, 0, true);
300 else
302 if (quote_chain_split)
303 error ("-I- specified twice");
304 quote_chain_split = true;
305 split_quote_chain ();
306 inform ("obsolete option -I- used, please use -iquote instead");
308 break;
310 case OPT_M:
311 case OPT_MM:
312 /* When doing dependencies with -M or -MM, suppress normal
313 preprocessed output, but still do -dM etc. as software
314 depends on this. Preprocessed output does occur if -MD, -MMD
315 or environment var dependency generation is used. */
316 cpp_opts->deps.style = (code == OPT_M ? DEPS_SYSTEM: DEPS_USER);
317 flag_no_output = 1;
318 cpp_opts->inhibit_warnings = 1;
319 break;
321 case OPT_MD:
322 case OPT_MMD:
323 cpp_opts->deps.style = (code == OPT_MD ? DEPS_SYSTEM: DEPS_USER);
324 deps_file = arg;
325 break;
327 case OPT_MF:
328 deps_seen = true;
329 deps_file = arg;
330 break;
332 case OPT_MG:
333 deps_seen = true;
334 cpp_opts->deps.missing_files = true;
335 break;
337 case OPT_MP:
338 deps_seen = true;
339 cpp_opts->deps.phony_targets = true;
340 break;
342 case OPT_MQ:
343 case OPT_MT:
344 deps_seen = true;
345 defer_opt (code, arg);
346 break;
348 case OPT_P:
349 flag_no_line_commands = 1;
350 break;
352 case OPT_fworking_directory:
353 flag_working_directory = value;
354 break;
356 case OPT_U:
357 defer_opt (code, arg);
358 break;
360 case OPT_Wall:
361 set_Wunused (value);
362 set_Wformat (value);
363 set_Wimplicit (value);
364 warn_char_subscripts = value;
365 warn_missing_braces = value;
366 warn_parentheses = value;
367 warn_return_type = value;
368 warn_sequence_point = value; /* Was C only. */
369 if (c_dialect_cxx ())
370 warn_sign_compare = value;
371 warn_switch = value;
372 warn_strict_aliasing = value;
374 /* Only warn about unknown pragmas that are not in system
375 headers. */
376 warn_unknown_pragmas = value;
378 /* We save the value of warn_uninitialized, since if they put
379 -Wuninitialized on the command line, we need to generate a
380 warning about not using it without also specifying -O. */
381 if (warn_uninitialized != 1)
382 warn_uninitialized = (value ? 2 : 0);
384 if (!c_dialect_cxx ())
385 /* We set this to 2 here, but 1 in -Wmain, so -ffreestanding
386 can turn it off only if it's not explicit. */
387 warn_main = value * 2;
388 else
390 /* C++-specific warnings. */
391 warn_nonvdtor = value;
392 warn_reorder = value;
393 warn_nontemplate_friend = value;
396 cpp_opts->warn_trigraphs = value;
397 cpp_opts->warn_comments = value;
398 cpp_opts->warn_num_sign_change = value;
399 cpp_opts->warn_multichar = value; /* Was C++ only. */
400 break;
402 case OPT_Wcomment:
403 case OPT_Wcomments:
404 cpp_opts->warn_comments = value;
405 break;
407 case OPT_Wdeprecated:
408 cpp_opts->warn_deprecated = value;
409 break;
411 case OPT_Wdiv_by_zero:
412 warn_div_by_zero = value;
413 break;
415 case OPT_Wendif_labels:
416 cpp_opts->warn_endif_labels = value;
417 break;
419 case OPT_Werror:
420 cpp_opts->warnings_are_errors = value;
421 global_dc->warning_as_error_requested = value;
422 break;
424 case OPT_Werror_implicit_function_declaration:
425 mesg_implicit_function_declaration = 2;
426 break;
428 case OPT_Wformat:
429 set_Wformat (value);
430 break;
432 case OPT_Wformat_:
433 set_Wformat (atoi (arg));
434 break;
436 case OPT_Wimplicit:
437 set_Wimplicit (value);
438 break;
440 case OPT_Wimport:
441 /* Silently ignore for now. */
442 break;
444 case OPT_Winvalid_pch:
445 cpp_opts->warn_invalid_pch = value;
446 break;
448 case OPT_Wmain:
449 if (value)
450 warn_main = 1;
451 else
452 warn_main = -1;
453 break;
455 case OPT_Wmissing_include_dirs:
456 cpp_opts->warn_missing_include_dirs = value;
457 break;
459 case OPT_Wmultichar:
460 cpp_opts->warn_multichar = value;
461 break;
463 case OPT_Wreturn_type:
464 warn_return_type = value;
465 break;
467 case OPT_Wsystem_headers:
468 cpp_opts->warn_system_headers = value;
469 break;
471 case OPT_Wtraditional:
472 cpp_opts->warn_traditional = value;
473 break;
475 case OPT_Wtrigraphs:
476 cpp_opts->warn_trigraphs = value;
477 break;
479 case OPT_Wundef:
480 cpp_opts->warn_undef = value;
481 break;
483 case OPT_Wunknown_pragmas:
484 /* Set to greater than 1, so that even unknown pragmas in
485 system headers will be warned about. */
486 warn_unknown_pragmas = value * 2;
487 break;
489 case OPT_Wunused_macros:
490 warn_unused_macros = value;
491 break;
493 case OPT_Wvariadic_macros:
494 warn_variadic_macros = value;
495 break;
497 case OPT_Wwrite_strings:
498 if (!c_dialect_cxx ())
499 flag_const_strings = value;
500 else
501 warn_write_strings = value;
502 break;
504 case OPT_ansi:
505 if (!c_dialect_cxx ())
506 set_std_c89 (false, true);
507 else
508 set_std_cxx98 (true);
509 break;
511 case OPT_d:
512 handle_OPT_d (arg);
513 break;
515 case OPT_fcond_mismatch:
516 if (!c_dialect_cxx ())
518 flag_cond_mismatch = value;
519 break;
521 /* Fall through. */
523 case OPT_fall_virtual:
524 case OPT_falt_external_templates:
525 case OPT_fenum_int_equiv:
526 case OPT_fexternal_templates:
527 case OPT_fguiding_decls:
528 case OPT_fhonor_std:
529 case OPT_fhuge_objects:
530 case OPT_flabels_ok:
531 case OPT_fname_mangling_version_:
532 case OPT_fnew_abi:
533 case OPT_fnonnull_objects:
534 case OPT_fsquangle:
535 case OPT_fstrict_prototype:
536 case OPT_fthis_is_variable:
537 case OPT_fvtable_thunks:
538 case OPT_fxref:
539 case OPT_fvtable_gc:
540 warning ("switch %qs is no longer supported", option->opt_text);
541 break;
543 case OPT_faccess_control:
544 flag_access_control = value;
545 break;
547 case OPT_fasm:
548 flag_no_asm = !value;
549 break;
551 case OPT_fbuiltin:
552 flag_no_builtin = !value;
553 break;
555 case OPT_fbuiltin_:
556 if (value)
557 result = 0;
558 else
559 disable_builtin_function (arg);
560 break;
562 case OPT_fdollars_in_identifiers:
563 cpp_opts->dollars_in_ident = value;
564 break;
566 case OPT_ffreestanding:
567 value = !value;
568 /* Fall through.... */
569 case OPT_fhosted:
570 flag_hosted = value;
571 flag_no_builtin = !value;
572 /* warn_main will be 2 if set by -Wall, 1 if set by -Wmain */
573 if (!value && warn_main == 2)
574 warn_main = 0;
575 break;
577 case OPT_fshort_double:
578 flag_short_double = value;
579 break;
581 case OPT_fshort_enums:
582 flag_short_enums = value;
583 break;
585 case OPT_fshort_wchar:
586 flag_short_wchar = value;
587 break;
589 case OPT_fsigned_bitfields:
590 flag_signed_bitfields = value;
591 break;
593 case OPT_fsigned_char:
594 flag_signed_char = value;
595 break;
597 case OPT_funsigned_bitfields:
598 flag_signed_bitfields = !value;
599 break;
601 case OPT_funsigned_char:
602 flag_signed_char = !value;
603 break;
605 case OPT_fcheck_new:
606 flag_check_new = value;
607 break;
609 case OPT_fconserve_space:
610 flag_conserve_space = value;
611 break;
613 case OPT_fconst_strings:
614 flag_const_strings = value;
615 break;
617 case OPT_fconstant_string_class_:
618 constant_string_class_name = arg;
619 break;
621 case OPT_fdefault_inline:
622 flag_default_inline = value;
623 break;
625 case OPT_felide_constructors:
626 flag_elide_constructors = value;
627 break;
629 case OPT_fenforce_eh_specs:
630 flag_enforce_eh_specs = value;
631 break;
633 case OPT_ffixed_form:
634 case OPT_ffixed_line_length_:
635 /* Fortran front end options ignored when preprocessing only. */
636 if (!flag_preprocess_only)
637 result = 0;
638 break;
640 case OPT_ffor_scope:
641 flag_new_for_scope = value;
642 break;
644 case OPT_fgnu_keywords:
645 flag_no_gnu_keywords = !value;
646 break;
648 case OPT_fgnu_runtime:
649 flag_next_runtime = !value;
650 break;
652 case OPT_fhandle_exceptions:
653 warning ("-fhandle-exceptions has been renamed -fexceptions (and is now on by default)");
654 flag_exceptions = value;
655 break;
657 case OPT_fimplement_inlines:
658 flag_implement_inlines = value;
659 break;
661 case OPT_fimplicit_inline_templates:
662 flag_implicit_inline_templates = value;
663 break;
665 case OPT_fimplicit_templates:
666 flag_implicit_templates = value;
667 break;
669 case OPT_fms_extensions:
670 flag_ms_extensions = value;
671 break;
673 case OPT_fnext_runtime:
674 flag_next_runtime = value;
675 break;
677 case OPT_fnil_receivers:
678 flag_nil_receivers = value;
679 break;
681 case OPT_fnonansi_builtins:
682 flag_no_nonansi_builtin = !value;
683 break;
685 case OPT_fobjc_exceptions:
686 flag_objc_exceptions = value;
687 break;
689 case OPT_fobjc_sjlj_exceptions:
690 flag_objc_sjlj_exceptions = value;
691 break;
693 case OPT_foperator_names:
694 cpp_opts->operator_names = value;
695 break;
697 case OPT_foptional_diags:
698 flag_optional_diags = value;
699 break;
701 case OPT_fpch_deps:
702 cpp_opts->restore_pch_deps = value;
703 break;
705 case OPT_fpch_preprocess:
706 flag_pch_preprocess = value;
707 break;
709 case OPT_fpermissive:
710 flag_permissive = value;
711 break;
713 case OPT_fpreprocessed:
714 cpp_opts->preprocessed = value;
715 break;
717 case OPT_freplace_objc_classes:
718 flag_replace_objc_classes = value;
719 break;
721 case OPT_frepo:
722 flag_use_repository = value;
723 if (value)
724 flag_implicit_templates = 0;
725 break;
727 case OPT_frtti:
728 flag_rtti = value;
729 break;
731 case OPT_fshow_column:
732 cpp_opts->show_column = value;
733 break;
735 case OPT_fstats:
736 flag_detailed_statistics = value;
737 break;
739 case OPT_ftabstop_:
740 /* It is documented that we silently ignore silly values. */
741 if (value >= 1 && value <= 100)
742 cpp_opts->tabstop = value;
743 break;
745 case OPT_fexec_charset_:
746 cpp_opts->narrow_charset = arg;
747 break;
749 case OPT_fwide_exec_charset_:
750 cpp_opts->wide_charset = arg;
751 break;
753 case OPT_finput_charset_:
754 cpp_opts->input_charset = arg;
755 break;
757 case OPT_ftemplate_depth_:
758 max_tinst_depth = value;
759 break;
761 case OPT_fuse_cxa_atexit:
762 flag_use_cxa_atexit = value;
763 break;
765 case OPT_fvisibility_inlines_hidden:
766 visibility_options.inlines_hidden = value;
767 break;
769 case OPT_fweak:
770 flag_weak = value;
771 break;
773 case OPT_fthreadsafe_statics:
774 flag_threadsafe_statics = value;
775 break;
777 case OPT_fzero_link:
778 flag_zero_link = value;
779 break;
781 case OPT_gen_decls:
782 flag_gen_declaration = 1;
783 break;
785 case OPT_idirafter:
786 add_path (xstrdup (arg), AFTER, 0, true);
787 break;
789 case OPT_imacros:
790 case OPT_include:
791 defer_opt (code, arg);
792 break;
794 case OPT_iprefix:
795 iprefix = arg;
796 break;
798 case OPT_iquote:
799 add_path (xstrdup (arg), QUOTE, 0, true);
800 break;
802 case OPT_isysroot:
803 sysroot = arg;
804 break;
806 case OPT_isystem:
807 add_path (xstrdup (arg), SYSTEM, 0, true);
808 break;
810 case OPT_iwithprefix:
811 add_prefixed_path (arg, SYSTEM);
812 break;
814 case OPT_iwithprefixbefore:
815 add_prefixed_path (arg, BRACKET);
816 break;
818 case OPT_lang_asm:
819 cpp_set_lang (parse_in, CLK_ASM);
820 cpp_opts->dollars_in_ident = false;
821 break;
823 case OPT_lang_objc:
824 cpp_opts->objc = 1;
825 break;
827 case OPT_nostdinc:
828 std_inc = false;
829 break;
831 case OPT_nostdinc__:
832 std_cxx_inc = false;
833 break;
835 case OPT_o:
836 if (!out_fname)
837 out_fname = arg;
838 else
839 error ("output filename specified twice");
840 break;
842 /* We need to handle the -pedantic switches here, rather than in
843 c_common_post_options, so that a subsequent -Wno-endif-labels
844 is not overridden. */
845 case OPT_pedantic_errors:
846 cpp_opts->pedantic_errors = 1;
847 /* Fall through. */
848 case OPT_pedantic:
849 cpp_opts->pedantic = 1;
850 cpp_opts->warn_endif_labels = 1;
851 break;
853 case OPT_print_objc_runtime_info:
854 print_struct_values = 1;
855 break;
857 case OPT_remap:
858 cpp_opts->remap = 1;
859 break;
861 case OPT_std_c__98:
862 case OPT_std_gnu__98:
863 set_std_cxx98 (code == OPT_std_c__98 /* ISO */);
864 break;
866 case OPT_std_c89:
867 case OPT_std_iso9899_1990:
868 case OPT_std_iso9899_199409:
869 set_std_c89 (code == OPT_std_iso9899_199409 /* c94 */, true /* ISO */);
870 break;
872 case OPT_std_gnu89:
873 set_std_c89 (false /* c94 */, false /* ISO */);
874 break;
876 case OPT_std_c99:
877 case OPT_std_c9x:
878 case OPT_std_iso9899_1999:
879 case OPT_std_iso9899_199x:
880 set_std_c99 (true /* ISO */);
881 break;
883 case OPT_std_gnu99:
884 case OPT_std_gnu9x:
885 set_std_c99 (false /* ISO */);
886 break;
888 case OPT_trigraphs:
889 cpp_opts->trigraphs = 1;
890 break;
892 case OPT_traditional_cpp:
893 cpp_opts->traditional = 1;
894 break;
896 case OPT_undef:
897 flag_undef = 1;
898 break;
900 case OPT_w:
901 cpp_opts->inhibit_warnings = 1;
902 break;
904 case OPT_v:
905 verbose = true;
906 break;
909 return result;
912 /* Post-switch processing. */
913 bool
914 c_common_post_options (const char **pfilename)
916 struct cpp_callbacks *cb;
918 /* Canonicalize the input and output filenames. */
919 if (in_fnames == NULL)
921 in_fnames = XNEWVEC (const char *, 1);
922 in_fnames[0] = "";
924 else if (strcmp (in_fnames[0], "-") == 0)
925 in_fnames[0] = "";
927 if (out_fname == NULL || !strcmp (out_fname, "-"))
928 out_fname = "";
930 if (cpp_opts->deps.style == DEPS_NONE)
931 check_deps_environment_vars ();
933 handle_deferred_opts ();
935 sanitize_cpp_opts ();
937 register_include_chains (parse_in, sysroot, iprefix,
938 std_inc, std_cxx_inc && c_dialect_cxx (), verbose);
940 flag_inline_trees = 1;
942 /* Use tree inlining. */
943 if (!flag_no_inline)
944 flag_no_inline = 1;
945 if (flag_inline_functions)
946 flag_inline_trees = 2;
948 /* If we are given more than one input file, we must use
949 unit-at-a-time mode. */
950 if (num_in_fnames > 1)
951 flag_unit_at_a_time = 1;
953 /* Default to ObjC sjlj exception handling if NeXT runtime. */
954 if (flag_objc_sjlj_exceptions < 0)
955 flag_objc_sjlj_exceptions = flag_next_runtime;
956 if (flag_objc_exceptions && !flag_objc_sjlj_exceptions)
957 flag_exceptions = 1;
959 /* -Wextra implies -Wsign-compare and -Wmissing-field-initializers,
960 but not if explicitly overridden. */
961 if (warn_sign_compare == -1)
962 warn_sign_compare = extra_warnings;
963 if (warn_missing_field_initializers == -1)
964 warn_missing_field_initializers = extra_warnings;
966 /* Special format checking options don't work without -Wformat; warn if
967 they are used. */
968 if (warn_format_y2k && !warn_format)
969 warning ("-Wformat-y2k ignored without -Wformat");
970 if (warn_format_extra_args && !warn_format)
971 warning ("-Wformat-extra-args ignored without -Wformat");
972 if (warn_format_zero_length && !warn_format)
973 warning ("-Wformat-zero-length ignored without -Wformat");
974 if (warn_format_nonliteral && !warn_format)
975 warning ("-Wformat-nonliteral ignored without -Wformat");
976 if (warn_format_security && !warn_format)
977 warning ("-Wformat-security ignored without -Wformat");
978 if (warn_missing_format_attribute && !warn_format)
979 warning ("-Wmissing-format-attribute ignored without -Wformat");
981 /* C99 requires special handling of complex multiplication and division;
982 -ffast-math and -fcx-limited-range are handled in process_options. */
983 if (flag_isoc99)
984 flag_complex_method = 2;
986 if (flag_preprocess_only)
988 /* Open the output now. We must do so even if flag_no_output is
989 on, because there may be other output than from the actual
990 preprocessing (e.g. from -dM). */
991 if (out_fname[0] == '\0')
992 out_stream = stdout;
993 else
994 out_stream = fopen (out_fname, "w");
996 if (out_stream == NULL)
998 fatal_error ("opening output file %s: %m", out_fname);
999 return false;
1002 if (num_in_fnames > 1)
1003 error ("too many filenames given. Type %s --help for usage",
1004 progname);
1006 init_pp_output (out_stream);
1008 else
1010 init_c_lex ();
1012 /* Yuk. WTF is this? I do know ObjC relies on it somewhere. */
1013 input_location = UNKNOWN_LOCATION;
1016 cb = cpp_get_callbacks (parse_in);
1017 cb->file_change = cb_file_change;
1018 cb->dir_change = cb_dir_change;
1019 cpp_post_options (parse_in);
1021 input_location = UNKNOWN_LOCATION;
1023 /* If an error has occurred in cpplib, note it so we fail
1024 immediately. */
1025 errorcount += cpp_errors (parse_in);
1027 *pfilename = this_input_filename
1028 = cpp_read_main_file (parse_in, in_fnames[0]);
1029 /* Don't do any compilation or preprocessing if there is no input file. */
1030 if (this_input_filename == NULL)
1032 errorcount++;
1033 return false;
1036 if (flag_working_directory
1037 && flag_preprocess_only && !flag_no_line_commands)
1038 pp_dir_change (parse_in, get_src_pwd ());
1040 return flag_preprocess_only;
1043 /* Front end initialization common to C, ObjC and C++. */
1044 bool
1045 c_common_init (void)
1047 /* Set up preprocessor arithmetic. Must be done after call to
1048 c_common_nodes_and_builtins for type nodes to be good. */
1049 cpp_opts->precision = TYPE_PRECISION (intmax_type_node);
1050 cpp_opts->char_precision = TYPE_PRECISION (char_type_node);
1051 cpp_opts->int_precision = TYPE_PRECISION (integer_type_node);
1052 cpp_opts->wchar_precision = TYPE_PRECISION (wchar_type_node);
1053 cpp_opts->unsigned_wchar = TYPE_UNSIGNED (wchar_type_node);
1054 cpp_opts->bytes_big_endian = BYTES_BIG_ENDIAN;
1056 /* This can't happen until after wchar_precision and bytes_big_endian
1057 are known. */
1058 cpp_init_iconv (parse_in);
1060 if (flag_preprocess_only)
1062 finish_options ();
1063 preprocess_file (parse_in);
1064 return false;
1067 /* Has to wait until now so that cpplib has its hash table. */
1068 init_pragma ();
1070 return true;
1073 /* Initialize the integrated preprocessor after debug output has been
1074 initialized; loop over each input file. */
1075 void
1076 c_common_parse_file (int set_yydebug)
1078 unsigned int i;
1080 /* Enable parser debugging, if requested and we can. If requested
1081 and we can't, notify the user. */
1082 #if YYDEBUG != 0
1083 yydebug = set_yydebug;
1084 #else
1085 if (set_yydebug)
1086 warning ("YYDEBUG was not defined at build time, -dy ignored");
1087 #endif
1089 i = 0;
1090 for (;;)
1092 finish_options ();
1093 pch_init ();
1094 push_file_scope ();
1095 c_parse_file ();
1096 finish_file ();
1097 pop_file_scope ();
1099 if (++i >= num_in_fnames)
1100 break;
1101 cpp_undef_all (parse_in);
1102 this_input_filename
1103 = cpp_read_main_file (parse_in, in_fnames[i]);
1104 /* If an input file is missing, abandon further compilation.
1105 cpplib has issued a diagnostic. */
1106 if (!this_input_filename)
1107 break;
1111 /* Common finish hook for the C, ObjC and C++ front ends. */
1112 void
1113 c_common_finish (void)
1115 FILE *deps_stream = NULL;
1117 if (cpp_opts->deps.style != DEPS_NONE)
1119 /* If -M or -MM was seen without -MF, default output to the
1120 output stream. */
1121 if (!deps_file)
1122 deps_stream = out_stream;
1123 else
1125 deps_stream = fopen (deps_file, deps_append ? "a": "w");
1126 if (!deps_stream)
1127 fatal_error ("opening dependency file %s: %m", deps_file);
1131 /* For performance, avoid tearing down cpplib's internal structures
1132 with cpp_destroy (). */
1133 errorcount += cpp_finish (parse_in, deps_stream);
1135 if (deps_stream && deps_stream != out_stream
1136 && (ferror (deps_stream) || fclose (deps_stream)))
1137 fatal_error ("closing dependency file %s: %m", deps_file);
1139 if (out_stream && (ferror (out_stream) || fclose (out_stream)))
1140 fatal_error ("when writing output to %s: %m", out_fname);
1143 /* Either of two environment variables can specify output of
1144 dependencies. Their value is either "OUTPUT_FILE" or "OUTPUT_FILE
1145 DEPS_TARGET", where OUTPUT_FILE is the file to write deps info to
1146 and DEPS_TARGET is the target to mention in the deps. They also
1147 result in dependency information being appended to the output file
1148 rather than overwriting it, and like Sun's compiler
1149 SUNPRO_DEPENDENCIES suppresses the dependency on the main file. */
1150 static void
1151 check_deps_environment_vars (void)
1153 char *spec;
1155 GET_ENVIRONMENT (spec, "DEPENDENCIES_OUTPUT");
1156 if (spec)
1157 cpp_opts->deps.style = DEPS_USER;
1158 else
1160 GET_ENVIRONMENT (spec, "SUNPRO_DEPENDENCIES");
1161 if (spec)
1163 cpp_opts->deps.style = DEPS_SYSTEM;
1164 cpp_opts->deps.ignore_main_file = true;
1168 if (spec)
1170 /* Find the space before the DEPS_TARGET, if there is one. */
1171 char *s = strchr (spec, ' ');
1172 if (s)
1174 /* Let the caller perform MAKE quoting. */
1175 defer_opt (OPT_MT, s + 1);
1176 *s = '\0';
1179 /* Command line -MF overrides environment variables and default. */
1180 if (!deps_file)
1181 deps_file = spec;
1183 deps_append = 1;
1184 deps_seen = true;
1188 /* Handle deferred command line switches. */
1189 static void
1190 handle_deferred_opts (void)
1192 size_t i;
1193 struct deps *deps;
1195 /* Avoid allocating the deps buffer if we don't need it.
1196 (This flag may be true without there having been -MT or -MQ
1197 options, but we'll still need the deps buffer.) */
1198 if (!deps_seen)
1199 return;
1201 deps = cpp_get_deps (parse_in);
1203 for (i = 0; i < deferred_count; i++)
1205 struct deferred_opt *opt = &deferred_opts[i];
1207 if (opt->code == OPT_MT || opt->code == OPT_MQ)
1208 deps_add_target (deps, opt->arg, opt->code == OPT_MQ);
1212 /* These settings are appropriate for GCC, but not necessarily so for
1213 cpplib as a library. */
1214 static void
1215 sanitize_cpp_opts (void)
1217 /* If we don't know what style of dependencies to output, complain
1218 if any other dependency switches have been given. */
1219 if (deps_seen && cpp_opts->deps.style == DEPS_NONE)
1220 error ("to generate dependencies you must specify either -M or -MM");
1222 /* -dM and dependencies suppress normal output; do it here so that
1223 the last -d[MDN] switch overrides earlier ones. */
1224 if (flag_dump_macros == 'M')
1225 flag_no_output = 1;
1227 /* Disable -dD, -dN and -dI if normal output is suppressed. Allow
1228 -dM since at least glibc relies on -M -dM to work. */
1229 /* Also, flag_no_output implies flag_no_line_commands, always. */
1230 if (flag_no_output)
1232 if (flag_dump_macros != 'M')
1233 flag_dump_macros = 0;
1234 flag_dump_includes = 0;
1235 flag_no_line_commands = 1;
1238 cpp_opts->unsigned_char = !flag_signed_char;
1239 cpp_opts->stdc_0_in_system_headers = STDC_0_IN_SYSTEM_HEADERS;
1241 /* We want -Wno-long-long to override -pedantic -std=non-c99
1242 and/or -Wtraditional, whatever the ordering. */
1243 cpp_opts->warn_long_long
1244 = warn_long_long && ((!flag_isoc99 && pedantic) || warn_traditional);
1246 /* Similarly with -Wno-variadic-macros. No check for c99 here, since
1247 this also turns off warnings about GCCs extension. */
1248 cpp_opts->warn_variadic_macros
1249 = warn_variadic_macros && (pedantic || warn_traditional);
1251 /* If we're generating preprocessor output, emit current directory
1252 if explicitly requested or if debugging information is enabled.
1253 ??? Maybe we should only do it for debugging formats that
1254 actually output the current directory? */
1255 if (flag_working_directory == -1)
1256 flag_working_directory = (debug_info_level != DINFO_LEVEL_NONE);
1259 /* Add include path with a prefix at the front of its name. */
1260 static void
1261 add_prefixed_path (const char *suffix, size_t chain)
1263 char *path;
1264 const char *prefix;
1265 size_t prefix_len, suffix_len;
1267 suffix_len = strlen (suffix);
1268 prefix = iprefix ? iprefix : cpp_GCC_INCLUDE_DIR;
1269 prefix_len = iprefix ? strlen (iprefix) : cpp_GCC_INCLUDE_DIR_len;
1271 path = (char *) xmalloc (prefix_len + suffix_len + 1);
1272 memcpy (path, prefix, prefix_len);
1273 memcpy (path + prefix_len, suffix, suffix_len);
1274 path[prefix_len + suffix_len] = '\0';
1276 add_path (path, chain, 0, false);
1279 /* Handle -D, -U, -A, -imacros, and the first -include. */
1280 static void
1281 finish_options (void)
1283 if (!cpp_opts->preprocessed)
1285 size_t i;
1287 cpp_change_file (parse_in, LC_RENAME, _("<built-in>"));
1288 cpp_init_builtins (parse_in, flag_hosted);
1289 c_cpp_builtins (parse_in);
1291 /* We're about to send user input to cpplib, so make it warn for
1292 things that we previously (when we sent it internal definitions)
1293 told it to not warn.
1295 C99 permits implementation-defined characters in identifiers.
1296 The documented meaning of -std= is to turn off extensions that
1297 conflict with the specified standard, and since a strictly
1298 conforming program cannot contain a '$', we do not condition
1299 their acceptance on the -std= setting. */
1300 cpp_opts->warn_dollars = (cpp_opts->pedantic && !cpp_opts->c99);
1302 cpp_change_file (parse_in, LC_RENAME, _("<command line>"));
1303 for (i = 0; i < deferred_count; i++)
1305 struct deferred_opt *opt = &deferred_opts[i];
1307 if (opt->code == OPT_D)
1308 cpp_define (parse_in, opt->arg);
1309 else if (opt->code == OPT_U)
1310 cpp_undef (parse_in, opt->arg);
1311 else if (opt->code == OPT_A)
1313 if (opt->arg[0] == '-')
1314 cpp_unassert (parse_in, opt->arg + 1);
1315 else
1316 cpp_assert (parse_in, opt->arg);
1320 /* Handle -imacros after -D and -U. */
1321 for (i = 0; i < deferred_count; i++)
1323 struct deferred_opt *opt = &deferred_opts[i];
1325 if (opt->code == OPT_imacros
1326 && cpp_push_include (parse_in, opt->arg))
1328 /* Disable push_command_line_include callback for now. */
1329 include_cursor = deferred_count + 1;
1330 cpp_scan_nooutput (parse_in);
1335 include_cursor = 0;
1336 push_command_line_include ();
1339 /* Give CPP the next file given by -include, if any. */
1340 static void
1341 push_command_line_include (void)
1343 while (include_cursor < deferred_count)
1345 struct deferred_opt *opt = &deferred_opts[include_cursor++];
1347 if (!cpp_opts->preprocessed && opt->code == OPT_include
1348 && cpp_push_include (parse_in, opt->arg))
1349 return;
1352 if (include_cursor == deferred_count)
1354 include_cursor++;
1355 /* -Wunused-macros should only warn about macros defined hereafter. */
1356 cpp_opts->warn_unused_macros = warn_unused_macros;
1357 /* Restore the line map from <command line>. */
1358 if (!cpp_opts->preprocessed)
1359 cpp_change_file (parse_in, LC_RENAME, this_input_filename);
1361 /* Set this here so the client can change the option if it wishes,
1362 and after stacking the main file so we don't trace the main file. */
1363 line_table.trace_includes = cpp_opts->print_include_names;
1367 /* File change callback. Has to handle -include files. */
1368 static void
1369 cb_file_change (cpp_reader * ARG_UNUSED (pfile),
1370 const struct line_map *new_map)
1372 if (flag_preprocess_only)
1373 pp_file_change (new_map);
1374 else
1375 fe_file_change (new_map);
1377 if (new_map == 0 || (new_map->reason == LC_LEAVE && MAIN_FILE_P (new_map)))
1378 push_command_line_include ();
1381 void
1382 cb_dir_change (cpp_reader * ARG_UNUSED (pfile), const char *dir)
1384 if (!set_src_pwd (dir))
1385 warning ("too late for # directive to set debug directory");
1388 /* Set the C 89 standard (with 1994 amendments if C94, without GNU
1389 extensions if ISO). There is no concept of gnu94. */
1390 static void
1391 set_std_c89 (int c94, int iso)
1393 cpp_set_lang (parse_in, c94 ? CLK_STDC94: iso ? CLK_STDC89: CLK_GNUC89);
1394 flag_iso = iso;
1395 flag_no_asm = iso;
1396 flag_no_gnu_keywords = iso;
1397 flag_no_nonansi_builtin = iso;
1398 flag_isoc94 = c94;
1399 flag_isoc99 = 0;
1402 /* Set the C 99 standard (without GNU extensions if ISO). */
1403 static void
1404 set_std_c99 (int iso)
1406 cpp_set_lang (parse_in, iso ? CLK_STDC99: CLK_GNUC99);
1407 flag_no_asm = iso;
1408 flag_no_nonansi_builtin = iso;
1409 flag_iso = iso;
1410 flag_isoc99 = 1;
1411 flag_isoc94 = 1;
1414 /* Set the C++ 98 standard (without GNU extensions if ISO). */
1415 static void
1416 set_std_cxx98 (int iso)
1418 cpp_set_lang (parse_in, iso ? CLK_CXX98: CLK_GNUCXX);
1419 flag_no_gnu_keywords = iso;
1420 flag_no_nonansi_builtin = iso;
1421 flag_iso = iso;
1424 /* Handle setting implicit to ON. */
1425 static void
1426 set_Wimplicit (int on)
1428 warn_implicit = on;
1429 warn_implicit_int = on;
1430 if (on)
1432 if (mesg_implicit_function_declaration != 2)
1433 mesg_implicit_function_declaration = 1;
1435 else
1436 mesg_implicit_function_declaration = 0;
1439 /* Args to -d specify what to dump. Silently ignore
1440 unrecognized options; they may be aimed at toplev.c. */
1441 static void
1442 handle_OPT_d (const char *arg)
1444 char c;
1446 while ((c = *arg++) != '\0')
1447 switch (c)
1449 case 'M': /* Dump macros only. */
1450 case 'N': /* Dump names. */
1451 case 'D': /* Dump definitions. */
1452 flag_dump_macros = c;
1453 break;
1455 case 'I':
1456 flag_dump_includes = 1;
1457 break;