aboutsummaryrefslogtreecommitdiff
path: root/gcc/gcc.c
diff options
context:
space:
mode:
authorEric Christopher <echristo@redhat.com>2005-07-12 18:10:32 +0000
committerEric Christopher <echristo@redhat.com>2005-07-12 18:10:32 +0000
commit192e785f02b20b6c95356c32916e41e3177085f9 (patch)
tree17f89da87c3c10babdf608c9118efba5f77280d4 /gcc/gcc.c
parent98007b353f3fe116b47dcbd71ea115039aefca83 (diff)
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: https://gcc.gnu.org/svn/gcc/trunk@101934 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/gcc.c')
-rw-r--r--gcc/gcc.c25
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)
{