00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 #include "config.h"
00023 #include "system.h"
00024 #include "coretypes.h"
00025 #include "tm.h"
00026 #include "tree.h"
00027 #include "c-common.h"
00028 #include "c-pragma.h"
00029 #include "flags.h"
00030 #include "toplev.h"
00031 #include "langhooks.h"
00032 #include "tree-inline.h"
00033 #include "diagnostic.h"
00034 #include "intl.h"
00035 #include "cppdefault.h"
00036 #include "c-incpath.h"
00037 #include "debug.h"
00038 #include "opts.h"
00039 #include "options.h"
00040 #include "mkdeps.h"
00041
00042 #ifndef DOLLARS_IN_IDENTIFIERS
00043 # define DOLLARS_IN_IDENTIFIERS true
00044 #endif
00045
00046 #ifndef TARGET_SYSTEM_ROOT
00047 # define TARGET_SYSTEM_ROOT NULL
00048 #endif
00049
00050 #ifndef TARGET_OPTF
00051 #define TARGET_OPTF(ARG)
00052 #endif
00053
00054
00055 static cpp_options *cpp_opts;
00056
00057
00058 static const char *this_input_filename;
00059
00060
00061 static const char *out_fname;
00062 static FILE *out_stream;
00063
00064
00065 static bool deps_append;
00066
00067
00068 static bool deps_seen;
00069
00070
00071 static bool verbose;
00072
00073
00074 static const char *deps_file;
00075
00076
00077 static const char *iprefix;
00078
00079
00080 static const char *sysroot = TARGET_SYSTEM_ROOT;
00081
00082
00083 static bool std_inc = true;
00084
00085
00086 static bool std_cxx_inc = true;
00087
00088
00089 static bool quote_chain_split;
00090
00091
00092 static bool warn_unused_macros;
00093
00094
00095 static bool warn_variadic_macros = true;
00096
00097
00098 static size_t deferred_count;
00099
00100
00101 static size_t include_cursor;
00102
00103 static void set_Wimplicit (int);
00104 static void handle_OPT_d (const char *);
00105 static void set_std_cxx98 (int);
00106 static void set_std_c89 (int, int);
00107 static void set_std_c99 (int);
00108 static void check_deps_environment_vars (void);
00109 static void handle_deferred_opts (void);
00110 static void sanitize_cpp_opts (void);
00111 static void add_prefixed_path (const char *, size_t);
00112 static void push_command_line_include (void);
00113 static void cb_file_change (cpp_reader *, const struct line_map *);
00114 static void cb_dir_change (cpp_reader *, const char *);
00115 static void finish_options (void);
00116
00117 #ifndef STDC_0_IN_SYSTEM_HEADERS
00118 #define STDC_0_IN_SYSTEM_HEADERS 0
00119 #endif
00120
00121
00122
00123 static void defer_opt (enum opt_code, const char *);
00124 static struct deferred_opt
00125 {
00126 enum opt_code code;
00127 const char *arg;
00128 } *deferred_opts;
00129
00130
00131
00132
00133
00134 bool
00135 c_common_missing_argument (const char *opt, size_t code)
00136 {
00137 switch (code)
00138 {
00139 default:
00140
00141 return false;
00142
00143 case OPT_fconstant_string_class_:
00144 error ("no class name specified with %qs", opt);
00145 break;
00146
00147 case OPT_A:
00148 error ("assertion missing after %qs", opt);
00149 break;
00150
00151 case OPT_D:
00152 case OPT_U:
00153 error ("macro name missing after %qs", opt);
00154 break;
00155
00156 case OPT_F:
00157 case OPT_I:
00158 case OPT_idirafter:
00159 case OPT_isysroot:
00160 case OPT_isystem:
00161 case OPT_iquote:
00162 error ("missing path after %qs", opt);
00163 break;
00164
00165 case OPT_MF:
00166 case OPT_MD:
00167 case OPT_MMD:
00168 case OPT_include:
00169 case OPT_imacros:
00170 case OPT_o:
00171 error ("missing filename after %qs", opt);
00172 break;
00173
00174 case OPT_MQ:
00175 case OPT_MT:
00176 error ("missing makefile target after %qs", opt);
00177 break;
00178 }
00179
00180 return true;
00181 }
00182
00183
00184 static void
00185 defer_opt (enum opt_code code, const char *arg)
00186 {
00187 deferred_opts[deferred_count].code = code;
00188 deferred_opts[deferred_count].arg = arg;
00189 deferred_count++;
00190 }
00191
00192
00193 unsigned int
00194 c_common_init_options (unsigned int argc, const char **argv)
00195 {
00196 static const unsigned int lang_flags[] = {CL_C, CL_ObjC, CL_CXX, CL_ObjCXX};
00197 unsigned int i, result;
00198
00199
00200
00201 if (c_dialect_cxx ())
00202 {
00203
00204
00205 diagnostic_line_cutoff (global_dc) = 80;
00206
00207
00208 diagnostic_prefixing_rule (global_dc) = DIAGNOSTICS_SHOW_PREFIX_ONCE;
00209 }
00210
00211 parse_in = cpp_create_reader (c_dialect_cxx () ? CLK_GNUCXX: CLK_GNUC89,
00212 ident_hash, &line_table);
00213
00214 cpp_opts = cpp_get_options (parse_in);
00215 cpp_opts->dollars_in_ident = DOLLARS_IN_IDENTIFIERS;
00216 cpp_opts->objc = c_dialect_objc ();
00217
00218
00219
00220 cpp_opts->warn_dollars = 0;
00221
00222 flag_const_strings = c_dialect_cxx ();
00223 flag_exceptions = c_dialect_cxx ();
00224 warn_pointer_arith = c_dialect_cxx ();
00225
00226 deferred_opts = XNEWVEC (struct deferred_opt, argc);
00227
00228 result = lang_flags[c_language];
00229
00230 if (c_language == clk_c)
00231 {
00232
00233
00234 for (i = 1; i < argc; i++)
00235 if (! strcmp (argv[i], "-lang-asm"))
00236 {
00237 result |= CL_C | CL_ObjC | CL_CXX | CL_ObjCXX;
00238 break;
00239 }
00240 }
00241
00242 return result;
00243 }
00244
00245
00246
00247
00248
00249 int
00250 c_common_handle_option (size_t scode, const char *arg, int value)
00251 {
00252 const struct cl_option *option = &cl_options[scode];
00253 enum opt_code code = (enum opt_code) scode;
00254 int result = 1;
00255
00256 switch (code)
00257 {
00258 default:
00259 if (cl_options[code].flags & (CL_C | CL_CXX | CL_ObjC | CL_ObjCXX))
00260 break;
00261 result = 0;
00262 break;
00263
00264 #ifdef TARG_SL
00265 case OPT_msoft_float:
00266 Float_Point_Support = true;
00267 break;
00268
00269 case OPT_mlong_long:
00270 Long_Long_Support = true;
00271 break;
00272 #endif
00273
00274 case OPT__output_pch_:
00275 pch_file = arg;
00276 break;
00277
00278 case OPT_A:
00279 defer_opt (code, arg);
00280 break;
00281
00282 case OPT_C:
00283 cpp_opts->discard_comments = 0;
00284 break;
00285
00286 case OPT_CC:
00287 cpp_opts->discard_comments = 0;
00288 cpp_opts->discard_comments_in_macro_exp = 0;
00289 break;
00290
00291 case OPT_D:
00292 defer_opt (code, arg);
00293 break;
00294
00295 case OPT_E:
00296 flag_preprocess_only = 1;
00297 break;
00298
00299 case OPT_H:
00300 cpp_opts->print_include_names = 1;
00301 break;
00302
00303 case OPT_F:
00304 TARGET_OPTF (xstrdup (arg));
00305 break;
00306
00307 case OPT_I:
00308 if (strcmp (arg, "-"))
00309 add_path (xstrdup (arg), BRACKET, 0, true);
00310 else
00311 {
00312 if (quote_chain_split)
00313 error ("-I- specified twice");
00314 quote_chain_split = true;
00315 split_quote_chain ();
00316 inform ("obsolete option -I- used, please use -iquote instead");
00317 }
00318 break;
00319
00320 case OPT_M:
00321 case OPT_MM:
00322
00323
00324
00325
00326 cpp_opts->deps.style = (code == OPT_M ? DEPS_SYSTEM: DEPS_USER);
00327 flag_no_output = 1;
00328 cpp_opts->inhibit_warnings = 1;
00329 break;
00330
00331 case OPT_MD:
00332 case OPT_MMD:
00333 cpp_opts->deps.style = (code == OPT_MD ? DEPS_SYSTEM: DEPS_USER);
00334 deps_file = arg;
00335 break;
00336
00337 case OPT_MF:
00338 deps_seen = true;
00339 deps_file = arg;
00340 break;
00341
00342 case OPT_MG:
00343 deps_seen = true;
00344 cpp_opts->deps.missing_files = true;
00345 break;
00346
00347 case OPT_MP:
00348 deps_seen = true;
00349 cpp_opts->deps.phony_targets = true;
00350 break;
00351
00352 case OPT_MQ:
00353 case OPT_MT:
00354 deps_seen = true;
00355 defer_opt (code, arg);
00356 break;
00357
00358 case OPT_P:
00359 flag_no_line_commands = 1;
00360 break;
00361
00362 case OPT_fworking_directory:
00363 flag_working_directory = value;
00364 break;
00365
00366 case OPT_U:
00367 defer_opt (code, arg);
00368 break;
00369
00370 case OPT_Wall:
00371 set_Wunused (value);
00372 set_Wformat (value);
00373 set_Wimplicit (value);
00374 warn_char_subscripts = value;
00375 warn_missing_braces = value;
00376 warn_parentheses = value;
00377 warn_return_type = value;
00378 warn_sequence_point = value;
00379 if (c_dialect_cxx ())
00380 warn_sign_compare = value;
00381 warn_switch = value;
00382 warn_strict_aliasing = value;
00383
00384
00385
00386 warn_unknown_pragmas = value;
00387
00388
00389
00390
00391 if (warn_uninitialized != 1)
00392 warn_uninitialized = (value ? 2 : 0);
00393
00394 if (!c_dialect_cxx ())
00395
00396
00397 warn_main = value * 2;
00398 else
00399 {
00400
00401 warn_nonvdtor = value;
00402 warn_reorder = value;
00403 warn_nontemplate_friend = value;
00404 }
00405
00406 cpp_opts->warn_trigraphs = value;
00407 cpp_opts->warn_comments = value;
00408 cpp_opts->warn_num_sign_change = value;
00409 cpp_opts->warn_multichar = value;
00410 break;
00411
00412 case OPT_Wcomment:
00413 case OPT_Wcomments:
00414 cpp_opts->warn_comments = value;
00415 break;
00416
00417 case OPT_Wdeprecated:
00418 cpp_opts->warn_deprecated = value;
00419 break;
00420
00421 case OPT_Wdiv_by_zero:
00422 warn_div_by_zero = value;
00423 break;
00424
00425 case OPT_Wendif_labels:
00426 cpp_opts->warn_endif_labels = value;
00427 break;
00428
00429 case OPT_Werror:
00430 cpp_opts->warnings_are_errors = value;
00431 global_dc->warning_as_error_requested = value;
00432 break;
00433
00434 case OPT_Werror_implicit_function_declaration:
00435 mesg_implicit_function_declaration = 2;
00436 break;
00437
00438 case OPT_Wformat:
00439 set_Wformat (value);
00440 break;
00441
00442 case OPT_Wformat_:
00443 set_Wformat (atoi (arg));
00444 break;
00445
00446 case OPT_Wimplicit:
00447 set_Wimplicit (value);
00448 break;
00449
00450 case OPT_Wimport:
00451
00452 break;
00453
00454 case OPT_Winvalid_pch:
00455 cpp_opts->warn_invalid_pch = value;
00456 break;
00457
00458 case OPT_Wmain:
00459 if (value)
00460 warn_main = 1;
00461 else
00462 warn_main = -1;
00463 break;
00464
00465 case OPT_Wmissing_include_dirs:
00466 cpp_opts->warn_missing_include_dirs = value;
00467 break;
00468
00469 case OPT_Wmultichar:
00470 cpp_opts->warn_multichar = value;
00471 break;
00472
00473 case OPT_Wreturn_type:
00474 warn_return_type = value;
00475 break;
00476
00477 case OPT_Wstrict_null_sentinel:
00478 warn_strict_null_sentinel = value;
00479 break;
00480
00481 case OPT_Wsystem_headers:
00482 cpp_opts->warn_system_headers = value;
00483 break;
00484
00485 case OPT_Wtraditional:
00486 cpp_opts->warn_traditional = value;
00487 break;
00488
00489 case OPT_Wtrigraphs:
00490 cpp_opts->warn_trigraphs = value;
00491 break;
00492
00493 case OPT_Wundef:
00494 cpp_opts->warn_undef = value;
00495 break;
00496
00497 case OPT_Wunknown_pragmas:
00498
00499
00500 warn_unknown_pragmas = value * 2;
00501 break;
00502
00503 case OPT_Wunused_macros:
00504 warn_unused_macros = value;
00505 break;
00506
00507 case OPT_Wvariadic_macros:
00508 warn_variadic_macros = value;
00509 break;
00510
00511 case OPT_Wwrite_strings:
00512 if (!c_dialect_cxx ())
00513 flag_const_strings = value;
00514 else
00515 warn_write_strings = value;
00516 break;
00517
00518 case OPT_ansi:
00519 if (!c_dialect_cxx ())
00520 set_std_c89 (false, true);
00521 else
00522 set_std_cxx98 (true);
00523 break;
00524
00525 case OPT_d:
00526 handle_OPT_d (arg);
00527 break;
00528
00529 case OPT_fcond_mismatch:
00530 if (!c_dialect_cxx ())
00531 {
00532 flag_cond_mismatch = value;
00533 break;
00534 }
00535
00536
00537 case OPT_fall_virtual:
00538 case OPT_falt_external_templates:
00539 case OPT_fenum_int_equiv:
00540 case OPT_fexternal_templates:
00541 case OPT_fguiding_decls:
00542 case OPT_fhonor_std:
00543 case OPT_fhuge_objects:
00544 case OPT_flabels_ok:
00545 case OPT_fname_mangling_version_:
00546 case OPT_fnew_abi:
00547 case OPT_fnonnull_objects:
00548 case OPT_fsquangle:
00549 case OPT_fstrict_prototype:
00550 case OPT_fthis_is_variable:
00551 case OPT_fvtable_thunks:
00552 case OPT_fxref:
00553 case OPT_fvtable_gc:
00554 warning ("switch %qs is no longer supported", option->opt_text);
00555 break;
00556
00557 case OPT_faccess_control:
00558 flag_access_control = value;
00559 break;
00560
00561 case OPT_fasm:
00562 flag_no_asm = !value;
00563 break;
00564
00565 case OPT_fbuiltin:
00566 flag_no_builtin = !value;
00567 break;
00568
00569 case OPT_fbuiltin_:
00570 if (value)
00571 result = 0;
00572 else
00573 disable_builtin_function (arg);
00574 break;
00575
00576 case OPT_fdollars_in_identifiers:
00577 cpp_opts->dollars_in_ident = value;
00578 break;
00579
00580 case OPT_ffreestanding:
00581 value = !value;
00582
00583 case OPT_fhosted:
00584 flag_hosted = value;
00585 flag_no_builtin = !value;
00586
00587 if (!value && warn_main == 2)
00588 warn_main = 0;
00589 break;
00590
00591 case OPT_fshort_double:
00592 flag_short_double = value;
00593 break;
00594
00595 case OPT_fshort_enums:
00596 flag_short_enums = value;
00597 break;
00598
00599 case OPT_fshort_wchar:
00600 flag_short_wchar = value;
00601 break;
00602
00603 case OPT_fsigned_bitfields:
00604 flag_signed_bitfields = value;
00605 break;
00606
00607 case OPT_fsigned_char:
00608 flag_signed_char = value;
00609 break;
00610
00611 case OPT_funsigned_bitfields:
00612 flag_signed_bitfields = !value;
00613 break;
00614
00615 case OPT_funsigned_char:
00616 flag_signed_char = !value;
00617 break;
00618
00619 case OPT_fcheck_new:
00620 flag_check_new = value;
00621 break;
00622
00623 case OPT_fconserve_space:
00624 flag_conserve_space = value;
00625 break;
00626
00627 case OPT_fconst_strings:
00628 flag_const_strings = value;
00629 break;
00630
00631 case OPT_fconstant_string_class_:
00632 constant_string_class_name = arg;
00633 break;
00634
00635 case OPT_fdefault_inline:
00636 flag_default_inline = value;
00637 break;
00638
00639 case OPT_felide_constructors:
00640 flag_elide_constructors = value;
00641 break;
00642
00643 case OPT_fenforce_eh_specs:
00644 flag_enforce_eh_specs = value;
00645 break;
00646
00647 case OPT_ffixed_form:
00648 case OPT_ffixed_line_length_:
00649
00650 if (!flag_preprocess_only)
00651 result = 0;
00652 break;
00653
00654 case OPT_ffor_scope:
00655 flag_new_for_scope = value;
00656 break;
00657
00658 case OPT_fgnu_keywords:
00659 flag_no_gnu_keywords = !value;
00660 break;
00661
00662 case OPT_fgnu_runtime:
00663 flag_next_runtime = !value;
00664 break;
00665
00666 case OPT_fhandle_exceptions:
00667 warning ("-fhandle-exceptions has been renamed -fexceptions (and is now on by default)");
00668 flag_exceptions = value;
00669 break;
00670
00671 case OPT_fimplement_inlines:
00672 flag_implement_inlines = value;
00673 break;
00674
00675 case OPT_fimplicit_inline_templates:
00676 flag_implicit_inline_templates = value;
00677 break;
00678
00679 case OPT_fimplicit_templates:
00680 flag_implicit_templates = value;
00681 break;
00682
00683 case OPT_fms_extensions:
00684 flag_ms_extensions = value;
00685 break;
00686
00687 case OPT_fnext_runtime:
00688 flag_next_runtime = value;
00689 break;
00690
00691 case OPT_fnil_receivers:
00692 flag_nil_receivers = value;
00693 break;
00694
00695 case OPT_fnonansi_builtins:
00696 flag_no_nonansi_builtin = !value;
00697 break;
00698
00699 case OPT_fobjc_exceptions:
00700 flag_objc_exceptions = value;
00701 break;
00702
00703 case OPT_fobjc_sjlj_exceptions:
00704 flag_objc_sjlj_exceptions = value;
00705 break;
00706
00707 case OPT_foperator_names:
00708 cpp_opts->operator_names = value;
00709 break;
00710
00711 case OPT_foptional_diags:
00712 flag_optional_diags = value;
00713 break;
00714
00715 case OPT_fpch_deps:
00716 cpp_opts->restore_pch_deps = value;
00717 break;
00718
00719 case OPT_fpch_preprocess:
00720 flag_pch_preprocess = value;
00721 break;
00722
00723 case OPT_fpermissive:
00724 flag_permissive = value;
00725 break;
00726
00727 case OPT_fpreprocessed:
00728 cpp_opts->preprocessed = value;
00729 break;
00730
00731 case OPT_freplace_objc_classes:
00732 flag_replace_objc_classes = value;
00733 break;
00734
00735 case OPT_frepo:
00736 flag_use_repository = value;
00737 if (value)
00738 flag_implicit_templates = 0;
00739 break;
00740
00741 case OPT_frtti:
00742 flag_rtti = value;
00743 break;
00744
00745 case OPT_fshow_column:
00746 cpp_opts->show_column = value;
00747 break;
00748
00749 case OPT_fstats:
00750 flag_detailed_statistics = value;
00751 break;
00752
00753 case OPT_ftabstop_:
00754
00755 if (value >= 1 && value <= 100)
00756 cpp_opts->tabstop = value;
00757 break;
00758
00759 case OPT_fexec_charset_:
00760 cpp_opts->narrow_charset = arg;
00761 break;
00762
00763 case OPT_fwide_exec_charset_:
00764 cpp_opts->wide_charset = arg;
00765 break;
00766
00767 case OPT_finput_charset_:
00768 cpp_opts->input_charset = arg;
00769 break;
00770
00771 case OPT_ftemplate_depth_:
00772 max_tinst_depth = value;
00773 break;
00774
00775 case OPT_fuse_cxa_atexit:
00776 flag_use_cxa_atexit = value;
00777 break;
00778
00779 case OPT_fvisibility_inlines_hidden:
00780 visibility_options.inlines_hidden = value;
00781 break;
00782
00783 case OPT_fweak:
00784 flag_weak = value;
00785 break;
00786
00787 case OPT_fthreadsafe_statics:
00788 flag_threadsafe_statics = value;
00789 break;
00790
00791 case OPT_fzero_link:
00792 flag_zero_link = value;
00793 break;
00794
00795 case OPT_gen_decls:
00796 flag_gen_declaration = 1;
00797 break;
00798
00799 case OPT_idirafter:
00800 add_path (xstrdup (arg), AFTER, 0, true);
00801 break;
00802
00803 case OPT_imacros:
00804 case OPT_include:
00805 defer_opt (code, arg);
00806 break;
00807
00808 case OPT_iprefix:
00809 iprefix = arg;
00810 break;
00811
00812 case OPT_iquote:
00813 add_path (xstrdup (arg), QUOTE, 0, true);
00814 break;
00815
00816 case OPT_isysroot:
00817 sysroot = arg;
00818 break;
00819
00820 case OPT_isystem:
00821 add_path (xstrdup (arg), SYSTEM, 0, true);
00822 break;
00823
00824 case OPT_iwithprefix:
00825 add_prefixed_path (arg, SYSTEM);
00826 break;
00827
00828 case OPT_iwithprefixbefore:
00829 add_prefixed_path (arg, BRACKET);
00830 break;
00831
00832 case OPT_lang_asm:
00833 cpp_set_lang (parse_in, CLK_ASM);
00834 cpp_opts->dollars_in_ident = false;
00835 break;
00836
00837 case OPT_lang_objc:
00838 cpp_opts->objc = 1;
00839 break;
00840
00841 case OPT_nostdinc:
00842 std_inc = false;
00843 break;
00844
00845 case OPT_nostdinc__:
00846 std_cxx_inc = false;
00847 break;
00848
00849 case OPT_o:
00850 if (!out_fname)
00851 out_fname = arg;
00852 else
00853 error ("output filename specified twice");
00854 break;
00855
00856
00857
00858
00859 case OPT_pedantic_errors:
00860 cpp_opts->pedantic_errors = 1;
00861
00862 case OPT_pedantic:
00863 cpp_opts->pedantic = 1;
00864 cpp_opts->warn_endif_labels = 1;
00865 break;
00866
00867 case OPT_print_objc_runtime_info:
00868 print_struct_values = 1;
00869 break;
00870
00871 case OPT_remap:
00872 cpp_opts->remap = 1;
00873 break;
00874
00875 case OPT_std_c__98:
00876 case OPT_std_gnu__98:
00877 set_std_cxx98 (code == OPT_std_c__98 );
00878 break;
00879
00880 case OPT_std_c89:
00881 case OPT_std_iso9899_1990:
00882 case OPT_std_iso9899_199409:
00883 set_std_c89 (code == OPT_std_iso9899_199409 , true );
00884 break;
00885
00886 case OPT_std_gnu89:
00887 set_std_c89 (false , false );
00888 break;
00889
00890 case OPT_std_c99:
00891 case OPT_std_c9x:
00892 case OPT_std_iso9899_1999:
00893 case OPT_std_iso9899_199x:
00894 set_std_c99 (true );
00895 break;
00896
00897 case OPT_std_gnu99:
00898 case OPT_std_gnu9x:
00899 set_std_c99 (false );
00900 break;
00901
00902 case OPT_trigraphs:
00903 cpp_opts->trigraphs = 1;
00904 break;
00905
00906 case OPT_traditional_cpp:
00907 cpp_opts->traditional = 1;
00908 break;
00909
00910 case OPT_undef:
00911 flag_undef = 1;
00912 break;
00913
00914 case OPT_w:
00915 cpp_opts->inhibit_warnings = 1;
00916 break;
00917
00918 case OPT_v:
00919 verbose = true;
00920 break;
00921 }
00922
00923 return result;
00924 }
00925
00926
00927 bool
00928 c_common_post_options (const char **pfilename)
00929 {
00930 struct cpp_callbacks *cb;
00931
00932
00933 if (in_fnames == NULL)
00934 {
00935 in_fnames = XNEWVEC (const char *, 1);
00936 in_fnames[0] = "";
00937 }
00938 else if (strcmp (in_fnames[0], "-") == 0)
00939 in_fnames[0] = "";
00940
00941 if (out_fname == NULL || !strcmp (out_fname, "-"))
00942 out_fname = "";
00943
00944 if (cpp_opts->deps.style == DEPS_NONE)
00945 check_deps_environment_vars ();
00946
00947 handle_deferred_opts ();
00948
00949 sanitize_cpp_opts ();
00950
00951 register_include_chains (parse_in, sysroot, iprefix,
00952 std_inc, std_cxx_inc && c_dialect_cxx (), verbose);
00953
00954 flag_inline_trees = 1;
00955
00956
00957 if (!flag_no_inline)
00958 flag_no_inline = 1;
00959 if (flag_inline_functions)
00960 flag_inline_trees = 2;
00961
00962
00963
00964 if (num_in_fnames > 1)
00965 flag_unit_at_a_time = 1;
00966
00967
00968 if (flag_objc_sjlj_exceptions < 0)
00969 flag_objc_sjlj_exceptions = flag_next_runtime;
00970 if (flag_objc_exceptions && !flag_objc_sjlj_exceptions)
00971 flag_exceptions = 1;
00972
00973
00974
00975 if (warn_sign_compare == -1)
00976 warn_sign_compare = extra_warnings;
00977 if (warn_missing_field_initializers == -1)
00978 warn_missing_field_initializers = extra_warnings;
00979
00980
00981
00982 if (warn_format_y2k && !warn_format)
00983 warning ("-Wformat-y2k ignored without -Wformat");
00984 if (warn_format_extra_args && !warn_format)
00985 warning ("-Wformat-extra-args ignored without -Wformat");
00986 if (warn_format_zero_length && !warn_format)
00987 warning ("-Wformat-zero-length ignored without -Wformat");
00988 if (warn_format_nonliteral && !warn_format)
00989 warning ("-Wformat-nonliteral ignored without -Wformat");
00990 if (warn_format_security && !warn_format)
00991 warning ("-Wformat-security ignored without -Wformat");
00992 if (warn_missing_format_attribute && !warn_format)
00993 warning ("-Wmissing-format-attribute ignored without -Wformat");
00994
00995
00996
00997 if (flag_isoc99)
00998 flag_complex_method = 2;
00999
01000 if (flag_preprocess_only)
01001 {
01002
01003
01004
01005 if (out_fname[0] == '\0')
01006 out_stream = stdout;
01007 else
01008 out_stream = fopen (out_fname, "w");
01009
01010 if (out_stream == NULL)
01011 {
01012 fatal_error ("opening output file %s: %m", out_fname);
01013 return false;
01014 }
01015
01016 if (num_in_fnames > 1)
01017 error ("too many filenames given. Type %s --help for usage",
01018 progname);
01019
01020 init_pp_output (out_stream);
01021 }
01022 else
01023 {
01024 init_c_lex ();
01025
01026
01027 input_location = UNKNOWN_LOCATION;
01028 }
01029
01030 cb = cpp_get_callbacks (parse_in);
01031 cb->file_change = cb_file_change;
01032 cb->dir_change = cb_dir_change;
01033 cpp_post_options (parse_in);
01034
01035 input_location = UNKNOWN_LOCATION;
01036
01037
01038
01039 errorcount += cpp_errors (parse_in);
01040
01041 *pfilename = this_input_filename
01042 = cpp_read_main_file (parse_in, in_fnames[0]);
01043
01044 if (this_input_filename == NULL)
01045 {
01046 errorcount++;
01047 return false;
01048 }
01049
01050 if (flag_working_directory
01051 && flag_preprocess_only && !flag_no_line_commands)
01052 pp_dir_change (parse_in, get_src_pwd ());
01053
01054 return flag_preprocess_only;
01055 }
01056
01057
01058 bool
01059 c_common_init (void)
01060 {
01061
01062
01063 cpp_opts->precision = TYPE_PRECISION (intmax_type_node);
01064 cpp_opts->char_precision = TYPE_PRECISION (char_type_node);
01065 cpp_opts->int_precision = TYPE_PRECISION (integer_type_node);
01066 cpp_opts->wchar_precision = TYPE_PRECISION (wchar_type_node);
01067 cpp_opts->unsigned_wchar = TYPE_UNSIGNED (wchar_type_node);
01068 cpp_opts->bytes_big_endian = BYTES_BIG_ENDIAN;
01069
01070
01071
01072 cpp_init_iconv (parse_in);
01073
01074 if (flag_preprocess_only)
01075 {
01076 finish_options ();
01077 preprocess_file (parse_in);
01078 return false;
01079 }
01080
01081
01082 init_pragma ();
01083
01084 return true;
01085 }
01086
01087
01088
01089 void
01090 c_common_parse_file (int set_yydebug)
01091 {
01092 unsigned int i;
01093
01094
01095
01096 #if YYDEBUG != 0
01097 yydebug = set_yydebug;
01098 #else
01099 if (set_yydebug)
01100 warning ("YYDEBUG was not defined at build time, -dy ignored");
01101 #endif
01102
01103 i = 0;
01104 for (;;)
01105 {
01106
01107 if (debug_hooks->start_end_main_source_file)
01108 (*debug_hooks->start_source_file) (0, this_input_filename);
01109 finish_options ();
01110 pch_init ();
01111 push_file_scope ();
01112 c_parse_file ();
01113 finish_file ();
01114 pop_file_scope ();
01115
01116 if (debug_hooks->start_end_main_source_file)
01117 (*debug_hooks->end_source_file) (0);
01118 if (++i >= num_in_fnames)
01119 break;
01120 cpp_undef_all (parse_in);
01121 this_input_filename
01122 = cpp_read_main_file (parse_in, in_fnames[i]);
01123
01124
01125 if (!this_input_filename)
01126 break;
01127 }
01128 }
01129
01130
01131 void
01132 c_common_finish (void)
01133 {
01134 FILE *deps_stream = NULL;
01135
01136 if (cpp_opts->deps.style != DEPS_NONE)
01137 {
01138
01139
01140 if (!deps_file)
01141 deps_stream = out_stream;
01142 else
01143 {
01144 deps_stream = fopen (deps_file, deps_append ? "a": "w");
01145 if (!deps_stream)
01146 fatal_error ("opening dependency file %s: %m", deps_file);
01147 }
01148 }
01149
01150
01151
01152 errorcount += cpp_finish (parse_in, deps_stream);
01153
01154 if (deps_stream && deps_stream != out_stream
01155 && (ferror (deps_stream) || fclose (deps_stream)))
01156 fatal_error ("closing dependency file %s: %m", deps_file);
01157
01158 if (out_stream && (ferror (out_stream) || fclose (out_stream)))
01159 fatal_error ("when writing output to %s: %m", out_fname);
01160 }
01161
01162
01163
01164
01165
01166
01167
01168
01169 static void
01170 check_deps_environment_vars (void)
01171 {
01172 char *spec;
01173
01174 GET_ENVIRONMENT (spec, "DEPENDENCIES_OUTPUT");
01175 if (spec)
01176 cpp_opts->deps.style = DEPS_USER;
01177 else
01178 {
01179 GET_ENVIRONMENT (spec, "SUNPRO_DEPENDENCIES");
01180 if (spec)
01181 {
01182 cpp_opts->deps.style = DEPS_SYSTEM;
01183 cpp_opts->deps.ignore_main_file = true;
01184 }
01185 }
01186
01187 if (spec)
01188 {
01189
01190 char *s = strchr (spec, ' ');
01191 if (s)
01192 {
01193
01194 defer_opt (OPT_MT, s + 1);
01195 *s = '\0';
01196 }
01197
01198
01199 if (!deps_file)
01200 deps_file = spec;
01201
01202 deps_append = 1;
01203 deps_seen = true;
01204 }
01205 }
01206
01207
01208 static void
01209 handle_deferred_opts (void)
01210 {
01211 size_t i;
01212 struct deps *deps;
01213
01214
01215
01216
01217 if (!deps_seen)
01218 return;
01219
01220 deps = cpp_get_deps (parse_in);
01221
01222 for (i = 0; i < deferred_count; i++)
01223 {
01224 struct deferred_opt *opt = &deferred_opts[i];
01225
01226 if (opt->code == OPT_MT || opt->code == OPT_MQ)
01227 deps_add_target (deps, opt->arg, opt->code == OPT_MQ);
01228 }
01229 }
01230
01231
01232
01233 static void
01234 sanitize_cpp_opts (void)
01235 {
01236
01237
01238 if (deps_seen && cpp_opts->deps.style == DEPS_NONE)
01239 error ("to generate dependencies you must specify either -M or -MM");
01240
01241
01242
01243 if (flag_dump_macros == 'M')
01244 flag_no_output = 1;
01245
01246
01247
01248
01249 if (flag_no_output)
01250 {
01251 if (flag_dump_macros != 'M')
01252 flag_dump_macros = 0;
01253 flag_dump_includes = 0;
01254 flag_no_line_commands = 1;
01255 }
01256
01257 cpp_opts->unsigned_char = !flag_signed_char;
01258 cpp_opts->stdc_0_in_system_headers = STDC_0_IN_SYSTEM_HEADERS;
01259
01260
01261
01262 cpp_opts->warn_long_long
01263 = warn_long_long && ((!flag_isoc99 && pedantic) || warn_traditional);
01264
01265
01266
01267 cpp_opts->warn_variadic_macros
01268 = warn_variadic_macros && (pedantic || warn_traditional);
01269
01270
01271
01272
01273
01274 if (flag_working_directory == -1)
01275 flag_working_directory = (debug_info_level != DINFO_LEVEL_NONE);
01276 }
01277
01278
01279 static void
01280 add_prefixed_path (const char *suffix, size_t chain)
01281 {
01282 char *path;
01283 const char *prefix;
01284 size_t prefix_len, suffix_len;
01285
01286 suffix_len = strlen (suffix);
01287 prefix = iprefix ? iprefix : cpp_GCC_INCLUDE_DIR;
01288 prefix_len = iprefix ? strlen (iprefix) : cpp_GCC_INCLUDE_DIR_len;
01289
01290 path = (char *) xmalloc (prefix_len + suffix_len + 1);
01291 memcpy (path, prefix, prefix_len);
01292 memcpy (path + prefix_len, suffix, suffix_len);
01293 path[prefix_len + suffix_len] = '\0';
01294
01295 add_path (path, chain, 0, false);
01296 }
01297
01298
01299 static void
01300 finish_options (void)
01301 {
01302 if (!cpp_opts->preprocessed)
01303 {
01304 size_t i;
01305
01306 cpp_change_file (parse_in, LC_RENAME, _("<built-in>"));
01307 cpp_init_builtins (parse_in, flag_hosted);
01308 c_cpp_builtins (parse_in);
01309
01310
01311
01312
01313
01314
01315
01316
01317
01318
01319 cpp_opts->warn_dollars = (cpp_opts->pedantic && !cpp_opts->c99);
01320
01321 cpp_change_file (parse_in, LC_RENAME, _("<command line>"));
01322 for (i = 0; i < deferred_count; i++)
01323 {
01324 struct deferred_opt *opt = &deferred_opts[i];
01325
01326 if (opt->code == OPT_D)
01327 cpp_define (parse_in, opt->arg);
01328 else if (opt->code == OPT_U)
01329 cpp_undef (parse_in, opt->arg);
01330 else if (opt->code == OPT_A)
01331 {
01332 if (opt->arg[0] == '-')
01333 cpp_unassert (parse_in, opt->arg + 1);
01334 else
01335 cpp_assert (parse_in, opt->arg);
01336 }
01337 }
01338
01339
01340 for (i = 0; i < deferred_count; i++)
01341 {
01342 struct deferred_opt *opt = &deferred_opts[i];
01343
01344 if (opt->code == OPT_imacros
01345 && cpp_push_include (parse_in, opt->arg))
01346 {
01347
01348 include_cursor = deferred_count + 1;
01349 cpp_scan_nooutput (parse_in);
01350 }
01351 }
01352 }
01353
01354 include_cursor = 0;
01355 push_command_line_include ();
01356 }
01357
01358
01359 static void
01360 push_command_line_include (void)
01361 {
01362 while (include_cursor < deferred_count)
01363 {
01364 struct deferred_opt *opt = &deferred_opts[include_cursor++];
01365
01366 if (!cpp_opts->preprocessed && opt->code == OPT_include
01367 && cpp_push_include (parse_in, opt->arg))
01368 return;
01369 }
01370
01371 if (include_cursor == deferred_count)
01372 {
01373 include_cursor++;
01374
01375 cpp_opts->warn_unused_macros = warn_unused_macros;
01376
01377 if (!cpp_opts->preprocessed)
01378 cpp_change_file (parse_in, LC_RENAME, this_input_filename);
01379
01380
01381
01382 line_table.trace_includes = cpp_opts->print_include_names;
01383 }
01384 }
01385
01386
01387 static void
01388 cb_file_change (cpp_reader * ARG_UNUSED (pfile),
01389 const struct line_map *new_map)
01390 {
01391 if (flag_preprocess_only)
01392 pp_file_change (new_map);
01393 else
01394 fe_file_change (new_map);
01395
01396 if (new_map == 0 || (new_map->reason == LC_LEAVE && MAIN_FILE_P (new_map)))
01397 push_command_line_include ();
01398 }
01399
01400 void
01401 cb_dir_change (cpp_reader * ARG_UNUSED (pfile), const char *dir)
01402 {
01403 if (!set_src_pwd (dir))
01404 warning ("too late for # directive to set debug directory");
01405 }
01406
01407
01408
01409 static void
01410 set_std_c89 (int c94, int iso)
01411 {
01412 cpp_set_lang (parse_in, c94 ? CLK_STDC94: iso ? CLK_STDC89: CLK_GNUC89);
01413 flag_iso = iso;
01414 flag_no_asm = iso;
01415 flag_no_gnu_keywords = iso;
01416 flag_no_nonansi_builtin = iso;
01417 flag_isoc94 = c94;
01418 flag_isoc99 = 0;
01419 }
01420
01421
01422 static void
01423 set_std_c99 (int iso)
01424 {
01425 cpp_set_lang (parse_in, iso ? CLK_STDC99: CLK_GNUC99);
01426 flag_no_asm = iso;
01427 flag_no_nonansi_builtin = iso;
01428 flag_iso = iso;
01429 flag_isoc99 = 1;
01430 flag_isoc94 = 1;
01431 }
01432
01433
01434 static void
01435 set_std_cxx98 (int iso)
01436 {
01437 cpp_set_lang (parse_in, iso ? CLK_CXX98: CLK_GNUCXX);
01438 flag_no_gnu_keywords = iso;
01439 flag_no_nonansi_builtin = iso;
01440 flag_iso = iso;
01441 }
01442
01443
01444 static void
01445 set_Wimplicit (int on)
01446 {
01447 warn_implicit = on;
01448 warn_implicit_int = on;
01449 if (on)
01450 {
01451 if (mesg_implicit_function_declaration != 2)
01452 mesg_implicit_function_declaration = 1;
01453 }
01454 else
01455 mesg_implicit_function_declaration = 0;
01456 }
01457
01458
01459
01460 static void
01461 handle_OPT_d (const char *arg)
01462 {
01463 char c;
01464
01465 while ((c = *arg++) != '\0')
01466 switch (c)
01467 {
01468 case 'M':
01469 case 'N':
01470 case 'D':
01471 flag_dump_macros = c;
01472 break;
01473
01474 case 'I':
01475 flag_dump_includes = 1;
01476 break;
01477 }
01478 }