OSDN Git Service

[libcpp/ChangeLog]
[pf3gnuchains/gcc-fork.git] / gcc / c-opts.c
1 /* C/ObjC/C++ command line option handling.
2    Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
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 "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 #include "c-tree.h"             /* For c_cpp_error.  */
44
45 #ifndef DOLLARS_IN_IDENTIFIERS
46 # define DOLLARS_IN_IDENTIFIERS true
47 #endif
48
49 #ifndef TARGET_SYSTEM_ROOT
50 # define TARGET_SYSTEM_ROOT NULL
51 #endif
52
53 #ifndef TARGET_OPTF
54 #define TARGET_OPTF(ARG)
55 #endif
56
57 /* CPP's options.  */
58 cpp_options *cpp_opts;
59
60 /* Input filename.  */
61 static const char *this_input_filename;
62
63 /* Filename and stream for preprocessed output.  */
64 static const char *out_fname;
65 static FILE *out_stream;
66
67 /* Append dependencies to deps_file.  */
68 static bool deps_append;
69
70 /* If dependency switches (-MF etc.) have been given.  */
71 static bool deps_seen;
72
73 /* If -v seen.  */
74 static bool verbose;
75
76 /* Dependency output file.  */
77 static const char *deps_file;
78
79 /* The prefix given by -iprefix, if any.  */
80 static const char *iprefix;
81
82 /* The multilib directory given by -imultilib, if any.  */
83 static const char *imultilib;
84
85 /* The system root, if any.  Overridden by -isysroot.  */
86 static const char *sysroot = TARGET_SYSTEM_ROOT;
87
88 /* Zero disables all standard directories for headers.  */
89 static bool std_inc = true;
90
91 /* Zero disables the C++-specific standard directories for headers.  */
92 static bool std_cxx_inc = true;
93
94 /* If the quote chain has been split by -I-.  */
95 static bool quote_chain_split;
96
97 /* If -Wunused-macros.  */
98 static bool warn_unused_macros;
99
100 /* If -Wvariadic-macros.  */
101 static bool warn_variadic_macros = true;
102
103 /* Number of deferred options.  */
104 static size_t deferred_count;
105
106 /* Number of deferred options scanned for -include.  */
107 static size_t include_cursor;
108
109 static void set_Wimplicit (int);
110 static void handle_OPT_d (const char *);
111 static void set_std_cxx98 (int);
112 static void set_std_cxx0x (int);
113 static void set_std_c89 (int, int);
114 static void set_std_c99 (int);
115 static void check_deps_environment_vars (void);
116 static void handle_deferred_opts (void);
117 static void sanitize_cpp_opts (void);
118 static void add_prefixed_path (const char *, size_t);
119 static void push_command_line_include (void);
120 static void cb_file_change (cpp_reader *, const struct line_map *);
121 static void cb_dir_change (cpp_reader *, const char *);
122 static void finish_options (void);
123
124 #ifndef STDC_0_IN_SYSTEM_HEADERS
125 #define STDC_0_IN_SYSTEM_HEADERS 0
126 #endif
127
128 /* Holds switches parsed by c_common_handle_option (), but whose
129    handling is deferred to c_common_post_options ().  */
130 static void defer_opt (enum opt_code, const char *);
131 static struct deferred_opt
132 {
133   enum opt_code code;
134   const char *arg;
135 } *deferred_opts;
136
137 /* Complain that switch CODE expects an argument but none was
138    provided.  OPT was the command-line option.  Return FALSE to get
139    the default message in opts.c, TRUE if we provide a specialized
140    one.  */
141 bool
142 c_common_missing_argument (const char *opt, size_t code)
143 {
144   switch (code)
145     {
146     default:
147       /* Pick up the default message.  */
148       return false;
149
150     case OPT_fconstant_string_class_:
151       error ("no class name specified with %qs", opt);
152       break;
153
154     case OPT_A:
155       error ("assertion missing after %qs", opt);
156       break;
157
158     case OPT_D:
159     case OPT_U:
160       error ("macro name missing after %qs", opt);
161       break;
162
163     case OPT_F:
164     case OPT_I:
165     case OPT_idirafter:
166     case OPT_isysroot:
167     case OPT_isystem:
168     case OPT_iquote:
169       error ("missing path after %qs", opt);
170       break;
171
172     case OPT_MF:
173     case OPT_MD:
174     case OPT_MMD:
175     case OPT_include:
176     case OPT_imacros:
177     case OPT_o:
178       error ("missing filename after %qs", opt);
179       break;
180
181     case OPT_MQ:
182     case OPT_MT:
183       error ("missing makefile target after %qs", opt);
184       break;
185     }
186
187   return true;
188 }
189
190 /* Defer option CODE with argument ARG.  */
191 static void
192 defer_opt (enum opt_code code, const char *arg)
193 {
194   deferred_opts[deferred_count].code = code;
195   deferred_opts[deferred_count].arg = arg;
196   deferred_count++;
197 }
198
199 /* Common initialization before parsing options.  */
200 unsigned int
201 c_common_init_options (unsigned int argc, const char **argv)
202 {
203   static const unsigned int lang_flags[] = {CL_C, CL_ObjC, CL_CXX, CL_ObjCXX};
204   unsigned int i, result;
205   struct cpp_callbacks *cb;
206
207   /* This is conditionalized only because that is the way the front
208      ends used to do it.  Maybe this should be unconditional?  */
209   if (c_dialect_cxx ())
210     {
211       /* By default wrap lines at 80 characters.  Is getenv
212          ("COLUMNS") preferable?  */
213       diagnostic_line_cutoff (global_dc) = 80;
214       /* By default, emit location information once for every
215          diagnostic message.  */
216       diagnostic_prefixing_rule (global_dc) = DIAGNOSTICS_SHOW_PREFIX_ONCE;
217     }
218
219   parse_in = cpp_create_reader (c_dialect_cxx () ? CLK_GNUCXX: CLK_GNUC89,
220                                 ident_hash, line_table);
221   cb = cpp_get_callbacks (parse_in);
222   cb->error = c_cpp_error;
223
224   cpp_opts = cpp_get_options (parse_in);
225   cpp_opts->dollars_in_ident = DOLLARS_IN_IDENTIFIERS;
226   cpp_opts->objc = c_dialect_objc ();
227
228   /* Reset to avoid warnings on internal definitions.  We set it just
229      before passing on command-line options to cpplib.  */
230   cpp_opts->warn_dollars = 0;
231
232   flag_exceptions = c_dialect_cxx ();
233   warn_pointer_arith = c_dialect_cxx ();
234   warn_write_strings = c_dialect_cxx();
235   flag_warn_unused_result = true;
236
237   /* By default, C99-like requirements for complex multiply and divide.  */
238   flag_complex_method = 2;
239
240   deferred_opts = XNEWVEC (struct deferred_opt, argc);
241
242   result = lang_flags[c_language];
243
244   if (c_language == clk_c)
245     {
246       /* If preprocessing assembly language, accept any of the C-family
247          front end options since the driver may pass them through.  */
248       for (i = 1; i < argc; i++)
249         if (! strcmp (argv[i], "-lang-asm"))
250           {
251             result |= CL_C | CL_ObjC | CL_CXX | CL_ObjCXX;
252             break;
253           }
254     }
255
256   return result;
257 }
258
259 /* Handle switch SCODE with argument ARG.  VALUE is true, unless no-
260    form of an -f or -W option was given.  Returns 0 if the switch was
261    invalid, a negative number to prevent language-independent
262    processing in toplev.c (a hack necessary for the short-term).  */
263 int
264 c_common_handle_option (size_t scode, const char *arg, int value)
265 {
266   const struct cl_option *option = &cl_options[scode];
267   enum opt_code code = (enum opt_code) scode;
268   int result = 1;
269
270   /* Prevent resetting the language standard to a C dialect when the driver
271      has already determined that we're looking at assembler input.  */
272   bool preprocessing_asm_p = (cpp_get_options (parse_in)->lang == CLK_ASM);
273  
274   switch (code)
275     {
276     default:
277       if (cl_options[code].flags & (CL_C | CL_CXX | CL_ObjC | CL_ObjCXX))
278         {
279           if ((option->flags & CL_TARGET)
280               && ! targetcm.handle_c_option (scode, arg, value))
281             result = 0;
282           break;
283         }
284       result = 0;
285       break;
286
287     case OPT__output_pch_:
288       pch_file = arg;
289       break;
290
291     case OPT_A:
292       defer_opt (code, arg);
293       break;
294
295     case OPT_C:
296       cpp_opts->discard_comments = 0;
297       break;
298
299     case OPT_CC:
300       cpp_opts->discard_comments = 0;
301       cpp_opts->discard_comments_in_macro_exp = 0;
302       break;
303
304     case OPT_D:
305       defer_opt (code, arg);
306       break;
307
308     case OPT_E:
309       flag_preprocess_only = 1;
310       break;
311
312     case OPT_H:
313       cpp_opts->print_include_names = 1;
314       break;
315
316     case OPT_F:
317       TARGET_OPTF (xstrdup (arg));
318       break;
319
320     case OPT_I:
321       if (strcmp (arg, "-"))
322         add_path (xstrdup (arg), BRACKET, 0, true);
323       else
324         {
325           if (quote_chain_split)
326             error ("-I- specified twice");
327           quote_chain_split = true;
328           split_quote_chain ();
329           inform (input_location, "obsolete option -I- used, please use -iquote instead");
330         }
331       break;
332
333     case OPT_M:
334     case OPT_MM:
335       /* When doing dependencies with -M or -MM, suppress normal
336          preprocessed output, but still do -dM etc. as software
337          depends on this.  Preprocessed output does occur if -MD, -MMD
338          or environment var dependency generation is used.  */
339       cpp_opts->deps.style = (code == OPT_M ? DEPS_SYSTEM: DEPS_USER);
340       flag_no_output = 1;
341       break;
342
343     case OPT_MD:
344     case OPT_MMD:
345       cpp_opts->deps.style = (code == OPT_MD ? DEPS_SYSTEM: DEPS_USER);
346       cpp_opts->deps.need_preprocessor_output = true;
347       deps_file = arg;
348       break;
349
350     case OPT_MF:
351       deps_seen = true;
352       deps_file = arg;
353       break;
354
355     case OPT_MG:
356       deps_seen = true;
357       cpp_opts->deps.missing_files = true;
358       break;
359
360     case OPT_MP:
361       deps_seen = true;
362       cpp_opts->deps.phony_targets = true;
363       break;
364
365     case OPT_MQ:
366     case OPT_MT:
367       deps_seen = true;
368       defer_opt (code, arg);
369       break;
370
371     case OPT_P:
372       flag_no_line_commands = 1;
373       break;
374
375     case OPT_fworking_directory:
376       flag_working_directory = value;
377       break;
378
379     case OPT_U:
380       defer_opt (code, arg);
381       break;
382
383     case OPT_Wall:
384       warn_unused = value;
385       set_Wformat (value);
386       set_Wimplicit (value);
387       warn_char_subscripts = value;
388       warn_missing_braces = value;
389       warn_parentheses = value;
390       warn_return_type = value;
391       warn_sequence_point = value;      /* Was C only.  */
392       warn_switch = value;
393       if (warn_strict_aliasing == -1)
394         set_Wstrict_aliasing (value);
395       warn_address = value;
396       if (warn_strict_overflow == -1)
397         warn_strict_overflow = value;
398       warn_array_bounds = value;
399       warn_volatile_register_var = value;
400       if (warn_jump_misses_init == -1)
401         warn_jump_misses_init = value;
402
403       /* Only warn about unknown pragmas that are not in system
404          headers.  */
405       warn_unknown_pragmas = value;
406
407       warn_uninitialized = value;
408
409       if (!c_dialect_cxx ())
410         {
411           /* We set this to 2 here, but 1 in -Wmain, so -ffreestanding
412              can turn it off only if it's not explicit.  */
413           if (warn_main == -1)
414             warn_main = (value ? 2 : 0);
415
416           /* In C, -Wall turns on -Wenum-compare, which we do here.
417              In C++ it is on by default, which is done in
418              c_common_post_options.  */
419           if (warn_enum_compare == -1)
420             warn_enum_compare = value;
421         }
422       else
423         {
424           /* C++-specific warnings.  */
425           warn_sign_compare = value;
426           warn_reorder = value;
427           warn_cxx0x_compat = value;
428         }
429
430       cpp_opts->warn_trigraphs = value;
431       cpp_opts->warn_comments = value;
432       cpp_opts->warn_num_sign_change = value;
433
434       if (warn_pointer_sign == -1)
435         warn_pointer_sign = value;
436       break;
437
438     case OPT_Wbuiltin_macro_redefined:
439       cpp_opts->warn_builtin_macro_redefined = value;
440       break;
441
442     case OPT_Wcomment:
443     case OPT_Wcomments:
444       cpp_opts->warn_comments = value;
445       break;
446
447     case OPT_Wc___compat:
448       /* Because -Wenum-compare is the default in C++, -Wc++-compat
449          implies -Wenum-compare.  */
450       if (warn_enum_compare == -1 && value)
451         warn_enum_compare = value;
452       /* Because C++ always warns about a goto which misses an
453          initialization, -Wc++-compat turns on -Wgoto-misses-init.  */
454       if (warn_jump_misses_init == -1 && value)
455         warn_jump_misses_init = value;
456       cpp_opts->warn_cxx_operator_names = value;
457       break;
458
459     case OPT_Wdeprecated:
460       cpp_opts->warn_deprecated = value;
461       break;
462
463     case OPT_Wendif_labels:
464       cpp_opts->warn_endif_labels = value;
465       break;
466
467     case OPT_Werror:
468       global_dc->warning_as_error_requested = value;
469       break;
470
471     case OPT_Werror_implicit_function_declaration: 
472       /* For backward compatibility, this is the same as
473          -Werror=implicit-function-declaration.  */
474       enable_warning_as_error ("implicit-function-declaration", value, CL_C | CL_ObjC); 
475       break;
476
477     case OPT_Wformat:
478       set_Wformat (value);
479       break;
480
481     case OPT_Wformat_:
482       set_Wformat (atoi (arg));
483       break;
484
485     case OPT_Wimplicit:
486       set_Wimplicit (value);
487       break;
488
489     case OPT_Wimport:
490       /* Silently ignore for now.  */
491       break;
492
493     case OPT_Winvalid_pch:
494       cpp_opts->warn_invalid_pch = value;
495       break;
496
497     case OPT_Wmissing_include_dirs:
498       cpp_opts->warn_missing_include_dirs = value;
499       break;
500
501     case OPT_Wmultichar:
502       cpp_opts->warn_multichar = value;
503       break;
504
505     case OPT_Wnormalized_:
506       if (!value || (arg && strcasecmp (arg, "none") == 0))
507         cpp_opts->warn_normalize = normalized_none;
508       else if (!arg || strcasecmp (arg, "nfkc") == 0)
509         cpp_opts->warn_normalize = normalized_KC;
510       else if (strcasecmp (arg, "id") == 0)
511         cpp_opts->warn_normalize = normalized_identifier_C;
512       else if (strcasecmp (arg, "nfc") == 0)
513         cpp_opts->warn_normalize = normalized_C;
514       else
515         error ("argument %qs to %<-Wnormalized%> not recognized", arg);
516       break;
517
518     case OPT_Wreturn_type:
519       warn_return_type = value;
520       break;
521
522     case OPT_Wstrict_null_sentinel:
523       warn_strict_null_sentinel = value;
524       break;
525
526     case OPT_Wtraditional:
527       cpp_opts->warn_traditional = value;
528       break;
529
530     case OPT_Wtrigraphs:
531       cpp_opts->warn_trigraphs = value;
532       break;
533
534     case OPT_Wundef:
535       cpp_opts->warn_undef = value;
536       break;
537
538     case OPT_Wunknown_pragmas:
539       /* Set to greater than 1, so that even unknown pragmas in
540          system headers will be warned about.  */
541       warn_unknown_pragmas = value * 2;
542       break;
543
544     case OPT_Wunused_macros:
545       warn_unused_macros = value;
546       break;
547
548     case OPT_Wvariadic_macros:
549       warn_variadic_macros = value;
550       break;
551
552     case OPT_Wwrite_strings:
553       warn_write_strings = value;
554       break;
555
556     case OPT_Weffc__:
557       warn_ecpp = value;
558       if (value)
559         warn_nonvdtor = true;
560       break;
561
562     case OPT_ansi:
563       if (!c_dialect_cxx ())
564         set_std_c89 (false, true);
565       else
566         set_std_cxx98 (true);
567       break;
568
569     case OPT_d:
570       handle_OPT_d (arg);
571       break;
572
573     case OPT_fcond_mismatch:
574       if (!c_dialect_cxx ())
575         {
576           flag_cond_mismatch = value;
577           break;
578         }
579       /* Fall through.  */
580
581     case OPT_fall_virtual:
582     case OPT_falt_external_templates:
583     case OPT_fenum_int_equiv:
584     case OPT_fexternal_templates:
585     case OPT_fguiding_decls:
586     case OPT_fhonor_std:
587     case OPT_fhuge_objects:
588     case OPT_flabels_ok:
589     case OPT_fname_mangling_version_:
590     case OPT_fnew_abi:
591     case OPT_fnonnull_objects:
592     case OPT_fsquangle:
593     case OPT_fstrict_prototype:
594     case OPT_fthis_is_variable:
595     case OPT_fvtable_thunks:
596     case OPT_fxref:
597     case OPT_fvtable_gc:
598       warning (0, "switch %qs is no longer supported", option->opt_text);
599       break;
600
601     case OPT_faccess_control:
602       flag_access_control = value;
603       break;
604
605     case OPT_fasm:
606       flag_no_asm = !value;
607       break;
608
609     case OPT_fbuiltin:
610       flag_no_builtin = !value;
611       break;
612
613     case OPT_fbuiltin_:
614       if (value)
615         result = 0;
616       else
617         disable_builtin_function (arg);
618       break;
619
620     case OPT_fdirectives_only:
621       cpp_opts->directives_only = value;
622       break;
623
624     case OPT_fdollars_in_identifiers:
625       cpp_opts->dollars_in_ident = value;
626       break;
627
628     case OPT_ffreestanding:
629       value = !value;
630       /* Fall through....  */
631     case OPT_fhosted:
632       flag_hosted = value;
633       flag_no_builtin = !value;
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_fpretty_templates:
830       flag_pretty_templates = value;
831       break;
832
833     case OPT_fzero_link:
834       flag_zero_link = value;
835       break;
836
837     case OPT_gen_decls:
838       flag_gen_declaration = 1;
839       break;
840
841     case OPT_femit_struct_debug_baseonly:
842       set_struct_debug_option ("base");
843       break;
844
845     case OPT_femit_struct_debug_reduced:
846       set_struct_debug_option ("dir:ord:sys,dir:gen:any,ind:base");
847       break;
848
849     case OPT_femit_struct_debug_detailed_:
850       set_struct_debug_option (arg);
851       break;
852
853     case OPT_idirafter:
854       add_path (xstrdup (arg), AFTER, 0, true);
855       break;
856
857     case OPT_imacros:
858     case OPT_include:
859       defer_opt (code, arg);
860       break;
861
862     case OPT_imultilib:
863       imultilib = arg;
864       break;
865
866     case OPT_iprefix:
867       iprefix = arg;
868       break;
869
870     case OPT_iquote:
871       add_path (xstrdup (arg), QUOTE, 0, true);
872       break;
873
874     case OPT_isysroot:
875       sysroot = arg;
876       break;
877
878     case OPT_isystem:
879       add_path (xstrdup (arg), SYSTEM, 0, true);
880       break;
881
882     case OPT_iwithprefix:
883       add_prefixed_path (arg, SYSTEM);
884       break;
885
886     case OPT_iwithprefixbefore:
887       add_prefixed_path (arg, BRACKET);
888       break;
889
890     case OPT_lang_asm:
891       cpp_set_lang (parse_in, CLK_ASM);
892       cpp_opts->dollars_in_ident = false;
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     case OPT_pedantic:
919       cpp_opts->pedantic = 1;
920       cpp_opts->warn_endif_labels = 1;
921       if (warn_pointer_sign == -1)
922         warn_pointer_sign = 1;
923       if (warn_overlength_strings == -1)
924         warn_overlength_strings = 1;
925       if (warn_main == -1)
926         warn_main = 2;
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_v:
993       verbose = true;
994       break;
995
996     case OPT_Wabi:
997       warn_psabi = value;
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   /* Excess precision other than "fast" requires front-end
1039      support.  */
1040   if (c_dialect_cxx ())
1041     {
1042       if (flag_excess_precision_cmdline == EXCESS_PRECISION_STANDARD
1043           && TARGET_FLT_EVAL_METHOD_NON_DEFAULT)
1044         sorry ("-fexcess-precision=standard for C++");
1045       flag_excess_precision_cmdline = EXCESS_PRECISION_FAST;
1046     }
1047   else if (flag_excess_precision_cmdline == EXCESS_PRECISION_DEFAULT)
1048     flag_excess_precision_cmdline = (flag_iso
1049                                      ? EXCESS_PRECISION_STANDARD
1050                                      : EXCESS_PRECISION_FAST);
1051
1052   /* By default we use C99 inline semantics in GNU99 or C99 mode.  C99
1053      inline semantics are not supported in GNU89 or C89 mode.  */
1054   if (flag_gnu89_inline == -1)
1055     flag_gnu89_inline = !flag_isoc99;
1056   else if (!flag_gnu89_inline && !flag_isoc99)
1057     error ("-fno-gnu89-inline is only supported in GNU99 or C99 mode");
1058
1059   /* Default to ObjC sjlj exception handling if NeXT runtime.  */
1060   if (flag_objc_sjlj_exceptions < 0)
1061     flag_objc_sjlj_exceptions = flag_next_runtime;
1062   if (flag_objc_exceptions && !flag_objc_sjlj_exceptions)
1063     flag_exceptions = 1;
1064
1065   /* -Wextra implies the following flags
1066      unless explicitly overridden.  */
1067   if (warn_type_limits == -1)
1068     warn_type_limits = extra_warnings;
1069   if (warn_clobbered == -1)
1070     warn_clobbered = extra_warnings;
1071   if (warn_empty_body == -1)
1072     warn_empty_body = extra_warnings;
1073   if (warn_sign_compare == -1)
1074     warn_sign_compare = extra_warnings;
1075   if (warn_missing_field_initializers == -1)
1076     warn_missing_field_initializers = extra_warnings;
1077   if (warn_missing_parameter_type == -1)
1078     warn_missing_parameter_type = extra_warnings;
1079   if (warn_old_style_declaration == -1)
1080     warn_old_style_declaration = extra_warnings;
1081   if (warn_override_init == -1)
1082     warn_override_init = extra_warnings;
1083   if (warn_ignored_qualifiers == -1)
1084     warn_ignored_qualifiers = extra_warnings;
1085
1086   /* -Wpointer-sign is disabled by default, but it is enabled if any
1087      of -Wall or -pedantic are given.  */
1088   if (warn_pointer_sign == -1)
1089     warn_pointer_sign = 0;
1090
1091   if (warn_strict_aliasing == -1)
1092     warn_strict_aliasing = 0;
1093   if (warn_strict_overflow == -1)
1094     warn_strict_overflow = 0;
1095   if (warn_jump_misses_init == -1)
1096     warn_jump_misses_init = 0;
1097
1098   /* -Woverlength-strings is off by default, but is enabled by -pedantic.
1099      It is never enabled in C++, as the minimum limit is not normative
1100      in that standard.  */
1101   if (warn_overlength_strings == -1 || c_dialect_cxx ())
1102     warn_overlength_strings = 0;
1103
1104   /* Wmain is enabled by default in C++ but not in C.  */
1105   /* Wmain is disabled by default for -ffreestanding (!flag_hosted),
1106      even if -Wall was given (warn_main will be 2 if set by -Wall, 1
1107      if set by -Wmain).  */
1108   if (warn_main == -1)
1109     warn_main = (c_dialect_cxx () && flag_hosted) ? 1 : 0;
1110   else if (warn_main == 2)
1111     warn_main = flag_hosted ? 1 : 0;
1112
1113   /* In C, -Wconversion enables -Wsign-conversion (unless disabled
1114      through -Wno-sign-conversion). While in C++,
1115      -Wsign-conversion needs to be requested explicitly.  */
1116   if (warn_sign_conversion == -1)
1117     warn_sign_conversion =  (c_dialect_cxx ()) ? 0 : warn_conversion;
1118
1119   /* In C, -Wall and -Wc++-compat enable -Wenum-compare, which we do
1120      in c_common_handle_option; if it has not yet been set, it is
1121      disabled by default.  In C++, it is enabled by default.  */
1122   if (warn_enum_compare == -1)
1123     warn_enum_compare = c_dialect_cxx () ? 1 : 0;
1124
1125   /* -Wpacked-bitfield-compat is on by default for the C languages.  The
1126      warning is issued in stor-layout.c which is not part of the front-end so
1127      we need to selectively turn it on here.  */
1128   if (warn_packed_bitfield_compat == -1)
1129     warn_packed_bitfield_compat = 1;
1130
1131   /* Special format checking options don't work without -Wformat; warn if
1132      they are used.  */
1133   if (!warn_format)
1134     {
1135       warning (OPT_Wformat_y2k,
1136                "-Wformat-y2k ignored without -Wformat");
1137       warning (OPT_Wformat_extra_args,
1138                "-Wformat-extra-args ignored without -Wformat");
1139       warning (OPT_Wformat_zero_length,
1140                "-Wformat-zero-length ignored without -Wformat");
1141       warning (OPT_Wformat_nonliteral,
1142                "-Wformat-nonliteral ignored without -Wformat");
1143       warning (OPT_Wformat_contains_nul,
1144                "-Wformat-contains-nul ignored without -Wformat");
1145       warning (OPT_Wformat_security,
1146                "-Wformat-security ignored without -Wformat");
1147     }
1148
1149   /* -Wimplicit-function-declaration is enabled by default for C99.  */
1150   if (warn_implicit_function_declaration == -1) 
1151     warn_implicit_function_declaration = flag_isoc99;
1152
1153   /* If we're allowing C++0x constructs, don't warn about C++0x
1154      compatibility problems.  */
1155   if (cxx_dialect == cxx0x)
1156     warn_cxx0x_compat = 0;
1157
1158   if (flag_preprocess_only)
1159     {
1160       /* Open the output now.  We must do so even if flag_no_output is
1161          on, because there may be other output than from the actual
1162          preprocessing (e.g. from -dM).  */
1163       if (out_fname[0] == '\0')
1164         out_stream = stdout;
1165       else
1166         out_stream = fopen (out_fname, "w");
1167
1168       if (out_stream == NULL)
1169         {
1170           fatal_error ("opening output file %s: %m", out_fname);
1171           return false;
1172         }
1173
1174       if (num_in_fnames > 1)
1175         error ("too many filenames given.  Type %s --help for usage",
1176                progname);
1177
1178       init_pp_output (out_stream);
1179     }
1180   else
1181     {
1182       init_c_lex ();
1183
1184       /* Yuk.  WTF is this?  I do know ObjC relies on it somewhere.  */
1185       input_location = UNKNOWN_LOCATION;
1186     }
1187
1188   cb = cpp_get_callbacks (parse_in);
1189   cb->file_change = cb_file_change;
1190   cb->dir_change = cb_dir_change;
1191   cpp_post_options (parse_in);
1192
1193   input_location = UNKNOWN_LOCATION;
1194
1195   *pfilename = this_input_filename
1196     = cpp_read_main_file (parse_in, in_fnames[0]);
1197   /* Don't do any compilation or preprocessing if there is no input file.  */
1198   if (this_input_filename == NULL)
1199     {
1200       errorcount++;
1201       return false;
1202     }
1203
1204   if (flag_working_directory
1205       && flag_preprocess_only && !flag_no_line_commands)
1206     pp_dir_change (parse_in, get_src_pwd ());
1207
1208   return flag_preprocess_only;
1209 }
1210
1211 /* Front end initialization common to C, ObjC and C++.  */
1212 bool
1213 c_common_init (void)
1214 {
1215   /* Set up preprocessor arithmetic.  Must be done after call to
1216      c_common_nodes_and_builtins for type nodes to be good.  */
1217   cpp_opts->precision = TYPE_PRECISION (intmax_type_node);
1218   cpp_opts->char_precision = TYPE_PRECISION (char_type_node);
1219   cpp_opts->int_precision = TYPE_PRECISION (integer_type_node);
1220   cpp_opts->wchar_precision = TYPE_PRECISION (wchar_type_node);
1221   cpp_opts->unsigned_wchar = TYPE_UNSIGNED (wchar_type_node);
1222   cpp_opts->bytes_big_endian = BYTES_BIG_ENDIAN;
1223
1224   /* This can't happen until after wchar_precision and bytes_big_endian
1225      are known.  */
1226   cpp_init_iconv (parse_in);
1227
1228   if (version_flag)
1229     c_common_print_pch_checksum (stderr);
1230
1231   /* Has to wait until now so that cpplib has its hash table.  */
1232   init_pragma ();
1233
1234   if (flag_preprocess_only)
1235     {
1236       finish_options ();
1237       preprocess_file (parse_in);
1238       return false;
1239     }
1240
1241   return true;
1242 }
1243
1244 /* Initialize the integrated preprocessor after debug output has been
1245    initialized; loop over each input file.  */
1246 void
1247 c_common_parse_file (int set_yydebug)
1248 {
1249   unsigned int i;
1250
1251   if (set_yydebug)
1252     switch (c_language)
1253       {
1254       case clk_c:
1255         warning(0, "The C parser does not support -dy, option ignored");
1256         break;
1257       case clk_objc:
1258         warning(0,
1259                 "The Objective-C parser does not support -dy, option ignored");
1260         break;
1261       case clk_cxx:
1262         warning(0, "The C++ parser does not support -dy, option ignored");
1263         break;
1264       case clk_objcxx:
1265         warning(0,
1266             "The Objective-C++ parser does not support -dy, option ignored");
1267         break;
1268       default:
1269         gcc_unreachable ();
1270     }
1271
1272   i = 0;
1273   for (;;)
1274     {
1275       /* Start the main input file, if the debug writer wants it. */
1276       if (debug_hooks->start_end_main_source_file)
1277         (*debug_hooks->start_source_file) (0, this_input_filename);
1278       finish_options ();
1279       pch_init ();
1280       push_file_scope ();
1281       c_parse_file ();
1282       finish_file ();
1283       pop_file_scope ();
1284       /* And end the main input file, if the debug writer wants it  */
1285       if (debug_hooks->start_end_main_source_file)
1286         (*debug_hooks->end_source_file) (0);
1287       if (++i >= num_in_fnames)
1288         break;
1289       cpp_undef_all (parse_in);
1290       cpp_clear_file_cache (parse_in);
1291       this_input_filename
1292         = cpp_read_main_file (parse_in, in_fnames[i]);
1293       /* If an input file is missing, abandon further compilation.
1294          cpplib has issued a diagnostic.  */
1295       if (!this_input_filename)
1296         break;
1297     }
1298 }
1299
1300 /* Common finish hook for the C, ObjC and C++ front ends.  */
1301 void
1302 c_common_finish (void)
1303 {
1304   FILE *deps_stream = NULL;
1305
1306   /* Don't write the deps file if there are errors.  */
1307   if (cpp_opts->deps.style != DEPS_NONE && errorcount == 0)
1308     {
1309       /* If -M or -MM was seen without -MF, default output to the
1310          output stream.  */
1311       if (!deps_file)
1312         deps_stream = out_stream;
1313       else
1314         {
1315           deps_stream = fopen (deps_file, deps_append ? "a": "w");
1316           if (!deps_stream)
1317             fatal_error ("opening dependency file %s: %m", deps_file);
1318         }
1319     }
1320
1321   /* For performance, avoid tearing down cpplib's internal structures
1322      with cpp_destroy ().  */
1323   cpp_finish (parse_in, deps_stream);
1324
1325   if (deps_stream && deps_stream != out_stream
1326       && (ferror (deps_stream) || fclose (deps_stream)))
1327     fatal_error ("closing dependency file %s: %m", deps_file);
1328
1329   if (out_stream && (ferror (out_stream) || fclose (out_stream)))
1330     fatal_error ("when writing output to %s: %m", out_fname);
1331 }
1332
1333 /* Either of two environment variables can specify output of
1334    dependencies.  Their value is either "OUTPUT_FILE" or "OUTPUT_FILE
1335    DEPS_TARGET", where OUTPUT_FILE is the file to write deps info to
1336    and DEPS_TARGET is the target to mention in the deps.  They also
1337    result in dependency information being appended to the output file
1338    rather than overwriting it, and like Sun's compiler
1339    SUNPRO_DEPENDENCIES suppresses the dependency on the main file.  */
1340 static void
1341 check_deps_environment_vars (void)
1342 {
1343   char *spec;
1344
1345   GET_ENVIRONMENT (spec, "DEPENDENCIES_OUTPUT");
1346   if (spec)
1347     cpp_opts->deps.style = DEPS_USER;
1348   else
1349     {
1350       GET_ENVIRONMENT (spec, "SUNPRO_DEPENDENCIES");
1351       if (spec)
1352         {
1353           cpp_opts->deps.style = DEPS_SYSTEM;
1354           cpp_opts->deps.ignore_main_file = true;
1355         }
1356     }
1357
1358   if (spec)
1359     {
1360       /* Find the space before the DEPS_TARGET, if there is one.  */
1361       char *s = strchr (spec, ' ');
1362       if (s)
1363         {
1364           /* Let the caller perform MAKE quoting.  */
1365           defer_opt (OPT_MT, s + 1);
1366           *s = '\0';
1367         }
1368
1369       /* Command line -MF overrides environment variables and default.  */
1370       if (!deps_file)
1371         deps_file = spec;
1372
1373       deps_append = 1;
1374       deps_seen = true;
1375     }
1376 }
1377
1378 /* Handle deferred command line switches.  */
1379 static void
1380 handle_deferred_opts (void)
1381 {
1382   size_t i;
1383   struct deps *deps;
1384
1385   /* Avoid allocating the deps buffer if we don't need it.
1386      (This flag may be true without there having been -MT or -MQ
1387      options, but we'll still need the deps buffer.)  */
1388   if (!deps_seen)
1389     return;
1390
1391   deps = cpp_get_deps (parse_in);
1392
1393   for (i = 0; i < deferred_count; i++)
1394     {
1395       struct deferred_opt *opt = &deferred_opts[i];
1396
1397       if (opt->code == OPT_MT || opt->code == OPT_MQ)
1398         deps_add_target (deps, opt->arg, opt->code == OPT_MQ);
1399     }
1400 }
1401
1402 /* These settings are appropriate for GCC, but not necessarily so for
1403    cpplib as a library.  */
1404 static void
1405 sanitize_cpp_opts (void)
1406 {
1407   /* If we don't know what style of dependencies to output, complain
1408      if any other dependency switches have been given.  */
1409   if (deps_seen && cpp_opts->deps.style == DEPS_NONE)
1410     error ("to generate dependencies you must specify either -M or -MM");
1411
1412   /* -dM and dependencies suppress normal output; do it here so that
1413      the last -d[MDN] switch overrides earlier ones.  */
1414   if (flag_dump_macros == 'M')
1415     flag_no_output = 1;
1416
1417   /* By default, -fdirectives-only implies -dD.  This allows subsequent phases
1418      to perform proper macro expansion.  */
1419   if (cpp_opts->directives_only && !cpp_opts->preprocessed && !flag_dump_macros)
1420     flag_dump_macros = 'D';
1421
1422   /* Disable -dD, -dN and -dI if normal output is suppressed.  Allow
1423      -dM since at least glibc relies on -M -dM to work.  */
1424   /* Also, flag_no_output implies flag_no_line_commands, always.  */
1425   if (flag_no_output)
1426     {
1427       if (flag_dump_macros != 'M')
1428         flag_dump_macros = 0;
1429       flag_dump_includes = 0;
1430       flag_no_line_commands = 1;
1431     }
1432   else if (cpp_opts->deps.missing_files)
1433     error ("-MG may only be used with -M or -MM");
1434
1435   cpp_opts->unsigned_char = !flag_signed_char;
1436   cpp_opts->stdc_0_in_system_headers = STDC_0_IN_SYSTEM_HEADERS;
1437
1438   /* Wlong-long is disabled by default. It is enabled by:
1439       [-pedantic | -Wtraditional] -std=[gnu|c]++98 ; or
1440       [-pedantic | -Wtraditional] -std=non-c99 . 
1441
1442       Either -Wlong-long or -Wno-long-long override any other settings.  */
1443   if (warn_long_long == -1)
1444     warn_long_long = ((pedantic || warn_traditional)
1445                       && (c_dialect_cxx () ? cxx_dialect == cxx98 : !flag_isoc99));
1446   cpp_opts->warn_long_long = warn_long_long;
1447
1448   /* Similarly with -Wno-variadic-macros.  No check for c99 here, since
1449      this also turns off warnings about GCCs extension.  */
1450   cpp_opts->warn_variadic_macros
1451     = warn_variadic_macros && (pedantic || warn_traditional);
1452
1453   /* If we're generating preprocessor output, emit current directory
1454      if explicitly requested or if debugging information is enabled.
1455      ??? Maybe we should only do it for debugging formats that
1456      actually output the current directory?  */
1457   if (flag_working_directory == -1)
1458     flag_working_directory = (debug_info_level != DINFO_LEVEL_NONE);
1459
1460   if (cpp_opts->directives_only)
1461     {
1462       if (warn_unused_macros)
1463         error ("-fdirectives-only is incompatible with -Wunused_macros");
1464       if (cpp_opts->traditional)
1465         error ("-fdirectives-only is incompatible with -traditional");
1466     }
1467 }
1468
1469 /* Add include path with a prefix at the front of its name.  */
1470 static void
1471 add_prefixed_path (const char *suffix, size_t chain)
1472 {
1473   char *path;
1474   const char *prefix;
1475   size_t prefix_len, suffix_len;
1476
1477   suffix_len = strlen (suffix);
1478   prefix     = iprefix ? iprefix : cpp_GCC_INCLUDE_DIR;
1479   prefix_len = iprefix ? strlen (iprefix) : cpp_GCC_INCLUDE_DIR_len;
1480
1481   path = (char *) xmalloc (prefix_len + suffix_len + 1);
1482   memcpy (path, prefix, prefix_len);
1483   memcpy (path + prefix_len, suffix, suffix_len);
1484   path[prefix_len + suffix_len] = '\0';
1485
1486   add_path (path, chain, 0, false);
1487 }
1488
1489 /* Handle -D, -U, -A, -imacros, and the first -include.  */
1490 static void
1491 finish_options (void)
1492 {
1493   if (!cpp_opts->preprocessed)
1494     {
1495       size_t i;
1496
1497       cb_file_change (parse_in,
1498                       linemap_add (line_table, LC_RENAME, 0,
1499                                    _("<built-in>"), 0));
1500
1501       cpp_init_builtins (parse_in, flag_hosted);
1502       c_cpp_builtins (parse_in);
1503
1504       /* We're about to send user input to cpplib, so make it warn for
1505          things that we previously (when we sent it internal definitions)
1506          told it to not warn.
1507
1508          C99 permits implementation-defined characters in identifiers.
1509          The documented meaning of -std= is to turn off extensions that
1510          conflict with the specified standard, and since a strictly
1511          conforming program cannot contain a '$', we do not condition
1512          their acceptance on the -std= setting.  */
1513       cpp_opts->warn_dollars = (cpp_opts->pedantic && !cpp_opts->c99);
1514
1515       cb_file_change (parse_in,
1516                       linemap_add (line_table, LC_RENAME, 0,
1517                                    _("<command-line>"), 0));
1518
1519       for (i = 0; i < deferred_count; i++)
1520         {
1521           struct deferred_opt *opt = &deferred_opts[i];
1522
1523           if (opt->code == OPT_D)
1524             cpp_define (parse_in, opt->arg);
1525           else if (opt->code == OPT_U)
1526             cpp_undef (parse_in, opt->arg);
1527           else if (opt->code == OPT_A)
1528             {
1529               if (opt->arg[0] == '-')
1530                 cpp_unassert (parse_in, opt->arg + 1);
1531               else
1532                 cpp_assert (parse_in, opt->arg);
1533             }
1534         }
1535
1536       /* Handle -imacros after -D and -U.  */
1537       for (i = 0; i < deferred_count; i++)
1538         {
1539           struct deferred_opt *opt = &deferred_opts[i];
1540
1541           if (opt->code == OPT_imacros
1542               && cpp_push_include (parse_in, opt->arg))
1543             {
1544               /* Disable push_command_line_include callback for now.  */
1545               include_cursor = deferred_count + 1;
1546               cpp_scan_nooutput (parse_in);
1547             }
1548         }
1549     }
1550   else if (cpp_opts->directives_only)
1551     cpp_init_special_builtins (parse_in);
1552
1553   include_cursor = 0;
1554   push_command_line_include ();
1555 }
1556
1557 /* Give CPP the next file given by -include, if any.  */
1558 static void
1559 push_command_line_include (void)
1560 {
1561   while (include_cursor < deferred_count)
1562     {
1563       struct deferred_opt *opt = &deferred_opts[include_cursor++];
1564
1565       if (!cpp_opts->preprocessed && opt->code == OPT_include
1566           && cpp_push_include (parse_in, opt->arg))
1567         return;
1568     }
1569
1570   if (include_cursor == deferred_count)
1571     {
1572       include_cursor++;
1573       /* -Wunused-macros should only warn about macros defined hereafter.  */
1574       cpp_opts->warn_unused_macros = warn_unused_macros;
1575       /* Restore the line map from <command line>.  */
1576       if (!cpp_opts->preprocessed)
1577         cpp_change_file (parse_in, LC_RENAME, this_input_filename);
1578
1579       /* Set this here so the client can change the option if it wishes,
1580          and after stacking the main file so we don't trace the main file.  */
1581       line_table->trace_includes = cpp_opts->print_include_names;
1582     }
1583 }
1584
1585 /* File change callback.  Has to handle -include files.  */
1586 static void
1587 cb_file_change (cpp_reader * ARG_UNUSED (pfile),
1588                 const struct line_map *new_map)
1589 {
1590   if (flag_preprocess_only)
1591     pp_file_change (new_map);
1592   else
1593     fe_file_change (new_map);
1594
1595   if (new_map == 0 || (new_map->reason == LC_LEAVE && MAIN_FILE_P (new_map)))
1596     push_command_line_include ();
1597 }
1598
1599 void
1600 cb_dir_change (cpp_reader * ARG_UNUSED (pfile), const char *dir)
1601 {
1602   if (!set_src_pwd (dir))
1603     warning (0, "too late for # directive to set debug directory");
1604 }
1605
1606 /* Set the C 89 standard (with 1994 amendments if C94, without GNU
1607    extensions if ISO).  There is no concept of gnu94.  */
1608 static void
1609 set_std_c89 (int c94, int iso)
1610 {
1611   cpp_set_lang (parse_in, c94 ? CLK_STDC94: iso ? CLK_STDC89: CLK_GNUC89);
1612   flag_iso = iso;
1613   flag_no_asm = iso;
1614   flag_no_gnu_keywords = iso;
1615   flag_no_nonansi_builtin = iso;
1616   flag_isoc94 = c94;
1617   flag_isoc99 = 0;
1618 }
1619
1620 /* Set the C 99 standard (without GNU extensions if ISO).  */
1621 static void
1622 set_std_c99 (int iso)
1623 {
1624   cpp_set_lang (parse_in, iso ? CLK_STDC99: CLK_GNUC99);
1625   flag_no_asm = iso;
1626   flag_no_nonansi_builtin = iso;
1627   flag_iso = iso;
1628   flag_isoc99 = 1;
1629   flag_isoc94 = 1;
1630 }
1631
1632 /* Set the C++ 98 standard (without GNU extensions if ISO).  */
1633 static void
1634 set_std_cxx98 (int iso)
1635 {
1636   cpp_set_lang (parse_in, iso ? CLK_CXX98: CLK_GNUCXX);
1637   flag_no_gnu_keywords = iso;
1638   flag_no_nonansi_builtin = iso;
1639   flag_iso = iso;
1640   cxx_dialect = cxx98;
1641 }
1642
1643 /* Set the C++ 0x working draft "standard" (without GNU extensions if ISO).  */
1644 static void
1645 set_std_cxx0x (int iso)
1646 {
1647   cpp_set_lang (parse_in, iso ? CLK_CXX0X: CLK_GNUCXX0X);
1648   flag_no_gnu_keywords = iso;
1649   flag_no_nonansi_builtin = iso;
1650   flag_iso = iso;
1651   cxx_dialect = cxx0x;
1652 }
1653
1654 /* Handle setting implicit to ON.  */
1655 static void
1656 set_Wimplicit (int on)
1657 {
1658   warn_implicit = on;
1659   warn_implicit_int = on;
1660   warn_implicit_function_declaration = on;
1661 }
1662
1663 /* Args to -d specify what to dump.  Silently ignore
1664    unrecognized options; they may be aimed at toplev.c.  */
1665 static void
1666 handle_OPT_d (const char *arg)
1667 {
1668   char c;
1669
1670   while ((c = *arg++) != '\0')
1671     switch (c)
1672       {
1673       case 'M':                 /* Dump macros only.  */
1674       case 'N':                 /* Dump names.  */
1675       case 'D':                 /* Dump definitions.  */
1676       case 'U':                 /* Dump used macros.  */
1677         flag_dump_macros = c;
1678         break;
1679
1680       case 'I':
1681         flag_dump_includes = 1;
1682         break;
1683       }
1684 }