diff options
author | echristo <echristo@138bc75d-0d04-0410-961f-82ee72b054a4> | 2005-07-12 18:10:32 +0000 |
---|---|---|
committer | echristo <echristo@138bc75d-0d04-0410-961f-82ee72b054a4> | 2005-07-12 18:10:32 +0000 |
commit | fbf54d9aef53586a4835659bc9989c62ff4daac4 (patch) | |
tree | 17f89da87c3c10babdf608c9118efba5f77280d4 /gcc/gcc.c | |
parent | 3bd64623062f8cbeb5efacb73f023457bd0b067e (diff) | |
download | gcc-fbf54d9aef53586a4835659bc9989c62ff4daac4.tar.gz |
2005-07-12 Eric Christopher <echristo@redhat.com>
* gcc.c (struct infile): Update comment for language.
(main): Rewrite input file resetting code.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@101934 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/gcc.c')
-rw-r--r-- | gcc/gcc.c | 25 |
1 files changed, 21 insertions, 4 deletions
diff --git a/gcc/gcc.c b/gcc/gcc.c index c137ad4f9ce..e3b8b496c46 100644 --- a/gcc/gcc.c +++ b/gcc/gcc.c @@ -2936,6 +2936,13 @@ static struct switchstr *switches; static int n_switches; +/* Language is one of three things: + + 1) The name of a real programming language. + 2) NULL, indicating that no one has figured out + what it is yet. + 3) '*', indicating that the file should be passed + to the linker. */ struct infile { const char *name; @@ -6553,11 +6560,21 @@ main (int argc, const char **argv) clear_failure_queue (); } - /* Reset the output file name to the first input file name, for use - with %b in LINK_SPEC on a target that prefers not to emit a.out - by default. */ + /* Reset the input file name to the first compile/object file name, for use + with %b in LINK_SPEC. We use the first input file that we can find + a compiler to compile it instead of using infiles.language since for + languages other than C we use aliases that we then lookup later. */ if (n_infiles > 0) - set_input (infiles[0].name); + { + int i; + + for (i = 0; i < n_infiles ; i++) + if (infiles[i].language && infiles[i].language != '*') + { + set_input (infiles[i].name); + break; + } + } if (error_count == 0) { |