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/gccspec.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/gccspec.c')
-rw-r--r-- | gcc/gccspec.c | 70 |
1 files changed, 36 insertions, 34 deletions
diff --git a/gcc/gccspec.c b/gcc/gccspec.c index 3a8c932..746ebf0 100644 --- a/gcc/gccspec.c +++ b/gcc/gccspec.c @@ -1,5 +1,5 @@ /* Specific flags and argument handling of the C front-end. - Copyright (C) 1999, 2001, 2003, 2007 Free Software Foundation, Inc. + Copyright (C) 1999, 2001, 2003, 2007, 2010 Free Software Foundation, Inc. This file is part of GCC. @@ -22,75 +22,77 @@ along with GCC; see the file COPYING3. If not see #include "coretypes.h" #include "tm.h" #include "gcc.h" +#include "opts.h" -/* Filter argc and argv before processing by the gcc driver proper. */ +/* Filter command line before processing by the gcc driver proper. */ void -lang_specific_driver (int *in_argc ATTRIBUTE_UNUSED, - const char *const **in_argv ATTRIBUTE_UNUSED, +lang_specific_driver (struct cl_decoded_option **in_decoded_options ATTRIBUTE_UNUSED, + unsigned int *in_decoded_options_count ATTRIBUTE_UNUSED, int *in_added_libraries ATTRIBUTE_UNUSED) { /* Systems which use the NeXT runtime by default should arrange for the shared libgcc to be used when -fgnu-runtime is passed through specs. */ #if defined(ENABLE_SHARED_LIBGCC) && ! defined(NEXT_OBJC_RUNTIME) - int i; + unsigned int i; /* The new argument list will be contained in this. */ - const char **arglist; + struct cl_decoded_option *new_decoded_options; /* True if we should add -shared-libgcc to the command-line. */ int shared_libgcc = 0; /* The total number of arguments with the new stuff. */ - int argc; + unsigned int argc; /* The argument list. */ - const char *const *argv; + struct cl_decoded_option *decoded_options; - argc = *in_argc; - argv = *in_argv; + argc = *in_decoded_options_count; + decoded_options = *in_decoded_options; for (i = 1; i < argc; i++) { - if (argv[i][0] == '-') + switch (decoded_options[i].opt_index) { - if (strcmp (argv[i], "-static-libgcc") == 0 - || strcmp (argv[i], "-static") == 0) - return; - } - else - { - int len; - - /* If the filename ends in .m or .mi, we are compiling ObjC - and want to pass -shared-libgcc. */ - len = strlen (argv[i]); - if ((len > 2 && argv[i][len - 2] == '.' && argv[i][len - 1] == 'm') - || (len > 3 && argv[i][len - 3] == '.' && argv[i][len - 2] == 'm' - && argv[i][len - 1] == 'i')) - shared_libgcc = 1; + case OPT_static_libgcc: + case OPT_static: + return; + + case OPT_SPECIAL_input_file: + { + const char *file = decoded_options[i].arg; + int len; + + /* If the filename ends in .m or .mi, we are compiling + ObjC and want to pass -shared-libgcc. */ + len = strlen (file); + if ((len > 2 && file[len - 2] == '.' && file[len - 1] == 'm') + || (len > 3 && file[len - 3] == '.' && file[len - 2] == 'm' + && file[len - 1] == 'i')) + shared_libgcc = 1; + } + break; } } if (shared_libgcc) { - /* Make sure to have room for the trailing NULL argument. */ - arglist = XNEWVEC (const char *, argc + 2); + new_decoded_options = XNEWVEC (struct cl_decoded_option, argc + 1); i = 0; do { - arglist[i] = argv[i]; + new_decoded_options[i] = decoded_options[i]; i++; } while (i < argc); - arglist[i++] = "-shared-libgcc"; - - arglist[i] = NULL; + generate_option (OPT_shared_libgcc, NULL, 1, CL_DRIVER, + &new_decoded_options[i++]); - *in_argc = i; - *in_argv = arglist; + *in_decoded_options_count = i; + *in_decoded_options = new_decoded_options; } #endif } |