diff options
author | Joseph Myers <joseph@codesourcery.com> | 2010-08-22 13:19:01 +0100 |
---|---|---|
committer | Joseph Myers <jsm28@gcc.gnu.org> | 2010-08-22 13:19:01 +0100 |
commit | d9d16a1956186ff3bcc0b9a4d559663ad505949a (patch) | |
tree | c0fcc55a02b851820af00ecab1b47d4cc06898cf /gcc/gcc.c | |
parent | 3607fdb2db5f194374dc33c7ed4c55165b7344d6 (diff) | |
download | gcc-d9d16a1956186ff3bcc0b9a4d559663ad505949a.zip gcc-d9d16a1956186ff3bcc0b9a4d559663ad505949a.tar.gz gcc-d9d16a1956186ff3bcc0b9a4d559663ad505949a.tar.bz2 |
Makefile.in (gccspec.o, cppspec.o): Update dependencies.
* Makefile.in (gccspec.o, cppspec.o): Update dependencies.
* common.opt (L, nodefaultlibs, nostdlib, pg, static): New
options.
* config/avr/avr.h (LIBSTDCXX): Remove initial "-l".
* config/freebsd.h (MATH_LIBRARY_PROFILE): Remove initial "-l".
* config/i386/djgpp.h (LIBSTDCXX): Remove initial "-l".
* config/rs6000/aix.h (LIBSTDCXX_STATIC): Remove initial "-l".
* config/s390/tpf.h (MATH_LIBRARY, LIBSTDCXX): Remove initial
"-l".
* cppspec.c: Include opts.h.
(lang_specific_driver): Use cl_decoded_option structures.
* doc/tm.texi.in (MATH_LIBRARY): Update documentation.
* doc/tm.texi: Regenerate.
* gcc.c (translate_options): Translate -d to -foutput-class-dir=.
(driver_handle_option): Allow driver options needing no special
processing.
(process_command): Decode options before call to
lang_specific_driver. Pass decoded options to
lang_specific_driver.
* gcc.h (lang_specific_driver): Update prototype.
* gccspec.c: Include opts.h.
(lang_specific_driver): Use cl_decoded_option structures.
* opts-common.c (option_ok_for_language, generate_option,
generate_option_input_file): New.
(decode_cmdline_option): Use option_ok_for_language.
(decode_cmdline_options_to_array): Use generate_option_input_file.
(handle_generated_option): Use generate_option.
* opts.h (generate_option, generate_option_input_file): Declare.
cp:
* Make-lang.in (g++spec.o): Update dependencies.
* g++spec.c: Include opts.h
(MATH_LIBRARY, LIBSTDCXX): Remove initial "-l".
(lang_specific_driver): Use cl_decoded_option structures.
fortran:
* Make-lang.in (gfortranspec.o): Update dependencies.
* gfortranspec.c: Include coretypes.h before gcc.h. Include
opts.h.
(MATH_LIBRARY, FORTRAN_LIBRARY): Remove initial "-l".
(ADD_ARG_LIBGFORTRAN, Option, lookup_option): Remove.
(g77_xargc): Make unsigned.
(g77_xargv): Change to g77_x_decoded_options.
(g77_newargc): Make unsigned.
(g77_newargv): Change to g77_new_decoded_options.
(strings_same, options_same): New.
(append_arg): Use cl_decoded_option structures.
(append_option): New.
(add_arg_libgfortran): New.
(lang_specific_driver): Use cl_decoded_option structures.
java:
* Make-lang.in (jvspec.o): Update dependencies.
* jvspec.c: Include opts.h.
(PARAM_ARG): Remove.
(find_spec_file): Do not add leading -specs=.
(lang_specific_driver): Use cl_decoded_option structures.
* lang.opt (C, CLASSPATH, D, bootclasspath, classpath, encoding,
extdirs, fmain=, s-bc-abi): New options.
From-SVN: r163459
Diffstat (limited to 'gcc/gcc.c')
-rw-r--r-- | gcc/gcc.c | 31 |
1 files changed, 18 insertions, 13 deletions
@@ -1368,6 +1368,16 @@ translate_options (int *argcp, const char *const **argvp) if (nskip + i > argc) nskip = argc - i; + /* Convert -d with a separate argument to + -foutput-class-dir= for Java. */ + if (c == 'd' && p[1] == 0 && argv[i + 1] != NULL) + { + newv[newindex++] = concat ("-foutput-class-dir=", argv[i + 1], + NULL); + nskip = 0; + i += 2; + } + while (nskip > 0) { newv[newindex++] = argv[i++]; @@ -3849,12 +3859,6 @@ driver_handle_option (const struct cl_decoded_option *decoded, do_save = false; break; - case OPT_S: - case OPT_c: - case OPT_E: - /* have_c already set in a prescan above. */ - break; - case OPT_o: have_o = 1; #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX) @@ -3878,7 +3882,10 @@ driver_handle_option (const struct cl_decoded_option *decoded, break; default: - gcc_unreachable (); + /* Various driver options need no special processing at this + point, having been handled in a prescan above or being + handled by specs. */ + break; } if (do_save) @@ -3983,10 +3990,11 @@ process_command (int argc, const char **argv) is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX or an automatically created GCC_EXEC_PREFIX from argv[0]. */ + decode_cmdline_options_to_array (argc, argv, CL_DRIVER, + &decoded_options, &decoded_options_count); + /* Do language-specific adjustment/addition of flags. */ - lang_specific_driver (&argc, - CONST_CAST2 (const char *const **, const char ***, - &argv), + lang_specific_driver (&decoded_options, &decoded_options_count, &added_libraries); if (gcc_exec_prefix) @@ -4118,9 +4126,6 @@ process_command (int argc, const char **argv) last_language_n_infiles = -1; - decode_cmdline_options_to_array (argc, argv, CL_DRIVER, - &decoded_options, &decoded_options_count); - handlers.unknown_option_callback = driver_unknown_option_callback; handlers.wrong_lang_callback = driver_wrong_lang_callback; handlers.post_handling_callback = driver_post_handling_callback; |