diff options
author | jsm28 <jsm28@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-11-12 23:26:56 +0000 |
---|---|---|
committer | jsm28 <jsm28@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-11-12 23:26:56 +0000 |
commit | 3c6c0e40fd80e2cd4909ef171f9a92efb5c6f348 (patch) | |
tree | ac9656c3417bd52665bd19c9ce7e400c0cee83d4 /gcc/opts-common.c | |
parent | cb74576fd7fb513113b0600ce43d689ff54b6684 (diff) | |
download | gcc-3c6c0e40fd80e2cd4909ef171f9a92efb5c6f348.tar.gz |
* Makefile.in (OPTS_H): Define.
(c-decl.o, c-family/c-common.o, c-family/c-opts.o,
c-family/c-pch.o, c-family/c-pragma.o, gcc.o, gccspec.o,
cppspec.o, options.o, gcc-options.o, lto-opts.o, opts.o,
opts-common.o, toplev.o, passes.o, matrix-reorg.o,
ipa-struct-reorg.o, PLUGIN_HEADERS): Use $(OPTS_H).
* gcc.c (driver_handle_option): Take location_t parameter.
(process_command, do_self_spec): Update calls to
read_cmdline_option.
* langhooks-def.h (lhd_handle_option): Take location_t parameter.
* langhooks.c (lhd_handle_option): Take location_t parameter.
* langhooks.h (handle_option): Take location_t parameter.
* lto-opts.c (lto_reissue_options): Update call to set_option.
* opts-common.c (handle_option): Make static. Take location_t
parameter and pass it to other functions.
(handle_generated_option): Take location_t parameter and pass it
to other functions.
(read_cmdline_option): Take location_t parameter and pass it to
other functions. Use warning_at and error_at.
(set_option): Take location_t parameter and pass it to other
functions.
* opts.c (common_handle_option): Take location_t parameter and
pass it to other functions.
(enable_warning_as_error): Make static. Take location_t parameter
and pass it to other functions.
(lang_handle_option): Take location_t parameter and pass it to
other functions.
(target_handle_option): Take location_t parameter.
(read_cmdline_options, maybe_default_option,
maybe_default_options, default_options_optimization,
decode_options): Take location_t parameter and pass it to other
functions.
* opts.h: Include input.h.
(struct cl_option_handler_func, decode_options, set_option,
handle_generated_option, read_cmdline_option): Take location_t
parameters.
(handle_option, enable_warning_as_error): Remove.
* toplev.c (toplev_main): Update call to decode_options.
ada:
* gcc-interface/Make-lang.in (ada/misc.o): Use $(OPTS_H).
* gcc-interface/misc.c (gnat_handle_option): Take location_t
parameter.
c-family:
* c-common.c (parse_optimize_options): Update call to
decode_options.
* c-common.h (c_common_handle_option): Update prototype.
* c-opts.c (c_common_handle_option): Take location_t parameter and
pass it to other functions.
cp:
* Make-lang.in (g++spec.o): Use $(OPTS_H).
fortran:
* Make-lang.in (gfortranspec.o): Use $(OPTS_H).
* gfortran.h (gfc_handle_option): Take location_t parameter.
* options.c (gfc_handle_option): Take location_t parameter.
java:
* Make-lang.in (jvspec.o, java/lang.o): Use $(OPTS_H).
* lang.c (java_handle_option): Take location_t parameter.
lto:
* Make-lang.in (lto/lto.o): Use $(OPTS_H).
* lto-lang.c (lto_handle_option): Take location_t parameter.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@166688 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/opts-common.c')
-rw-r--r-- | gcc/opts-common.c | 65 |
1 files changed, 34 insertions, 31 deletions
diff --git a/gcc/opts-common.c b/gcc/opts-common.c index af5d1b4868a..c114d4e1f04 100644 --- a/gcc/opts-common.c +++ b/gcc/opts-common.c @@ -722,17 +722,19 @@ keep: /* Handle option DECODED for the language indicated by LANG_MASK, using the handlers in HANDLERS and setting fields in OPTS and OPTS_SET. KIND is the diagnostic_t if this is a diagnostics - option, DK_UNSPECIFIED otherwise. GENERATED_P is true for an - option generated as part of processing another option or otherwise - generated internally, false for one explicitly passed by the user. - Returns false if the switch was invalid. DC is the diagnostic - context for options affecting diagnostics state, or NULL. */ + option, DK_UNSPECIFIED otherwise, and LOC is the location of the + option for options from the source file, UNKNOWN_LOCATION + otherwise. GENERATED_P is true for an option generated as part of + processing another option or otherwise generated internally, false + for one explicitly passed by the user. Returns false if the switch + was invalid. DC is the diagnostic context for options affecting + diagnostics state, or NULL. */ -bool +static bool handle_option (struct gcc_options *opts, struct gcc_options *opts_set, const struct cl_decoded_option *decoded, - unsigned int lang_mask, int kind, + unsigned int lang_mask, int kind, location_t loc, const struct cl_option_handlers *handlers, bool generated_p, diagnostic_context *dc) { @@ -745,13 +747,14 @@ handle_option (struct gcc_options *opts, if (flag_var) set_option (opts, (generated_p ? NULL : opts_set), - opt_index, value, arg, kind, dc); + opt_index, value, arg, kind, loc, dc); for (i = 0; i < handlers->num_handlers; i++) if (option->flags & handlers->handlers[i].mask) { if (!handlers->handlers[i].handler (opts, opts_set, decoded, - lang_mask, kind, handlers, dc)) + lang_mask, kind, loc, + handlers, dc)) return false; else handlers->post_handling_callback (decoded, @@ -770,15 +773,15 @@ bool handle_generated_option (struct gcc_options *opts, struct gcc_options *opts_set, size_t opt_index, const char *arg, int value, - unsigned int lang_mask, int kind, + unsigned int lang_mask, int kind, location_t loc, const struct cl_option_handlers *handlers, diagnostic_context *dc) { struct cl_decoded_option decoded; generate_option (opt_index, arg, value, lang_mask, &decoded); - return handle_option (opts, opts_set, &decoded, lang_mask, kind, handlers, - true, dc); + return handle_option (opts, opts_set, &decoded, lang_mask, kind, loc, + handlers, true, dc); } /* Fill in *DECODED with an option described by OPT_INDEX, ARG and @@ -836,15 +839,16 @@ generate_option_input_file (const char *file, decoded->errors = 0; } -/* Handle the switch DECODED for the language indicated by LANG_MASK, - using the handlers in *HANDLERS and setting fields in OPTS and - OPTS_SET and using diagnostic context DC (if not NULL) for +/* Handle the switch DECODED (location LOC) for the language indicated + by LANG_MASK, using the handlers in *HANDLERS and setting fields in + OPTS and OPTS_SET and using diagnostic context DC (if not NULL) for diagnostic options. */ void read_cmdline_option (struct gcc_options *opts, struct gcc_options *opts_set, struct cl_decoded_option *decoded, + location_t loc, unsigned int lang_mask, const struct cl_option_handlers *handlers, diagnostic_context *dc) @@ -853,12 +857,12 @@ read_cmdline_option (struct gcc_options *opts, const char *opt = decoded->orig_option_with_args_text; if (decoded->warn_message) - warning (0, decoded->warn_message, opt); + warning_at (loc, 0, decoded->warn_message, opt); if (decoded->opt_index == OPT_SPECIAL_unknown) { if (handlers->unknown_option_callback (decoded)) - error ("unrecognized command line option %qs", decoded->arg); + error_at (loc, "unrecognized command line option %qs", decoded->arg); return; } @@ -869,8 +873,8 @@ read_cmdline_option (struct gcc_options *opts, if (decoded->errors & CL_ERR_DISABLED) { - error ("command line option %qs" - " is not supported by this configuration", opt); + error_at (loc, "command line option %qs" + " is not supported by this configuration", opt); return; } @@ -883,35 +887,35 @@ read_cmdline_option (struct gcc_options *opts, if (decoded->errors & CL_ERR_MISSING_ARG) { if (option->missing_argument_error) - error (option->missing_argument_error, opt); + error_at (loc, option->missing_argument_error, opt); else - error ("missing argument to %qs", opt); + error_at (loc, "missing argument to %qs", opt); return; } if (decoded->errors & CL_ERR_UINT_ARG) { - error ("argument to %qs should be a non-negative integer", - option->opt_text); + error_at (loc, "argument to %qs should be a non-negative integer", + option->opt_text); return; } gcc_assert (!decoded->errors); if (!handle_option (opts, opts_set, decoded, lang_mask, DK_UNSPECIFIED, - handlers, false, dc)) - error ("unrecognized command line option %qs", opt); + loc, handlers, false, dc)) + error_at (loc, "unrecognized command line option %qs", opt); } /* Set any field in OPTS, and OPTS_SET if not NULL, for option - OPT_INDEX according to VALUE and ARG, diagnostic kind KIND, using - diagnostic context DC if not NULL for diagnostic - classification. */ + OPT_INDEX according to VALUE and ARG, diagnostic kind KIND, + location LOC, using diagnostic context DC if not NULL for + diagnostic classification. */ void set_option (struct gcc_options *opts, struct gcc_options *opts_set, int opt_index, int value, const char *arg, int kind, - diagnostic_context *dc) + location_t loc, diagnostic_context *dc) { const struct cl_option *option = &cl_options[opt_index]; void *flag_var = option_flag_var (opt_index, opts); @@ -958,8 +962,7 @@ set_option (struct gcc_options *opts, struct gcc_options *opts_set, if ((diagnostic_t) kind != DK_UNSPECIFIED && dc != NULL) - diagnostic_classify_diagnostic (dc, opt_index, (diagnostic_t) kind, - UNKNOWN_LOCATION); + diagnostic_classify_diagnostic (dc, opt_index, (diagnostic_t) kind, loc); } /* Return the address of the flag variable for option OPT_INDEX in |