diff options
author | espindola <espindola@138bc75d-0d04-0410-961f-82ee72b054a4> | 2009-04-16 12:57:50 +0000 |
---|---|---|
committer | espindola <espindola@138bc75d-0d04-0410-961f-82ee72b054a4> | 2009-04-16 12:57:50 +0000 |
commit | 39932bd229b90bbd1991a2663534b0facd237634 (patch) | |
tree | 880209f07ea612d1ce7811a96cabe4898bce80b8 /gcc/gcc.c | |
parent | 4e06d1d1057bacd630407c4fc4b731e4207152e3 (diff) | |
download | gcc-39932bd229b90bbd1991a2663534b0facd237634.tar.gz |
2009-04-16 Rafael Avila de Espindola <espindola@google.com>
* common.opt (fversion): New.
* gcc.c (print_version): New.
(process_command): Don't print the version. Just set print_version.
(main): Print version. Call subprocesses if print_version and
verbose_flag are set.
* opts.c (common_handle_option): Handle OPT_fversion.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@146183 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/gcc.c')
-rw-r--r-- | gcc/gcc.c | 43 |
1 files changed, 34 insertions, 9 deletions
diff --git a/gcc/gcc.c b/gcc/gcc.c index de429f87c41..5c697ea0146 100644 --- a/gcc/gcc.c +++ b/gcc/gcc.c @@ -169,6 +169,10 @@ static int print_multi_lib; static int print_help_list; +/* Flag saying to print the version of gcc and its sub-processes. */ + +static int print_version; + /* Flag saying to print the sysroot suffix used for searching for headers. */ @@ -3650,14 +3654,17 @@ process_command (int argc, const char **argv) else if (strcmp (argv[i], "-fversion") == 0) { /* translate_options () has turned --version into -fversion. */ - printf (_("%s %s%s\n"), programname, pkgversion_string, - version_string); - printf ("Copyright %s 2009 Free Software Foundation, Inc.\n", - _("(C)")); - fputs (_("This is free software; see the source for copying conditions. There is NO\n\ -warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"), - stdout); - exit (0); + print_version = 1; + + /* We will be passing a dummy file on to the sub-processes. */ + n_infiles++; + n_switches++; + + /* CPP driver cannot obtain switch from cc1_options. */ + if (is_cpp_driver) + add_preprocessor_option ("--version", strlen ("--version")); + add_assembler_option ("--version", strlen ("--version")); + add_linker_option ("--version", strlen ("--version")); } else if (strcmp (argv[i], "-fhelp") == 0) { @@ -4364,7 +4371,7 @@ warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n" error ("warning: '-x %s' after last input file has no effect", spec_lang); /* Ensure we only invoke each subprocess once. */ - if (print_subprocess_help || print_help_list) + if (print_subprocess_help || print_help_list || print_version) { n_infiles = 1; @@ -6667,6 +6674,24 @@ main (int argc, char **argv) fflush (stdout); } + if (print_version) + { + printf (_("%s %s%s\n"), programname, pkgversion_string, + version_string); + printf ("Copyright %s 2009 Free Software Foundation, Inc.\n", + _("(C)")); + fputs (_("This is free software; see the source for copying conditions. There is NO\n\ +warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"), + stdout); + if (! verbose_flag) + return 0; + + /* We do not exit here. We use the same mechanism of --help to print + the version of the sub-processes. */ + fputc ('\n', stdout); + fflush (stdout); + } + if (verbose_flag) { int n; |