summaryrefslogtreecommitdiff
path: root/gcc/gcc.c
diff options
context:
space:
mode:
authorechristo <echristo@138bc75d-0d04-0410-961f-82ee72b054a4>2005-07-12 18:10:32 +0000
committerechristo <echristo@138bc75d-0d04-0410-961f-82ee72b054a4>2005-07-12 18:10:32 +0000
commitfbf54d9aef53586a4835659bc9989c62ff4daac4 (patch)
tree17f89da87c3c10babdf608c9118efba5f77280d4 /gcc/gcc.c
parent3bd64623062f8cbeb5efacb73f023457bd0b067e (diff)
downloadgcc-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.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)
{