summaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorbothner <bothner@138bc75d-0d04-0410-961f-82ee72b054a4>2001-05-18 18:34:51 +0000
committerbothner <bothner@138bc75d-0d04-0410-961f-82ee72b054a4>2001-05-18 18:34:51 +0000
commitd210f3fff74356d78e758863a76d961f69971b4e (patch)
tree317916a4b2bad48f4f182a4e224dbad018ff6510 /gcc
parent943bf3c71fc70451d125c77a8d65af8d93ca1428 (diff)
downloadgcc-d210f3fff74356d78e758863a76d961f69971b4e.tar.gz
* jvspec.c (lang_specific_pre_link): Re-arrange the linker
command line so the jvgenmain-generated main program comes first. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@42270 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r--gcc/java/ChangeLog5
-rw-r--r--gcc/java/jvspec.c16
2 files changed, 20 insertions, 1 deletions
diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog
index 7fd7de5b6e3..677d507e630 100644
--- a/gcc/java/ChangeLog
+++ b/gcc/java/ChangeLog
@@ -1,3 +1,8 @@
+2001-05-18 Per Bothner <per@bothner.com>
+
+ * jvspec.c (lang_specific_pre_link): Re-arrange the linker
+ command line so the jvgenmain-generated main program comes first.
+
2001-05-15 Tom Tromey <tromey@redhat.com>
* class.c (build_utf8_ref): Don't generate identifier based on
diff --git a/gcc/java/jvspec.c b/gcc/java/jvspec.c
index c02071ff308..4a8c333db34 100644
--- a/gcc/java/jvspec.c
+++ b/gcc/java/jvspec.c
@@ -525,9 +525,23 @@ lang_specific_driver (in_argc, in_argv, in_added_libraries)
int
lang_specific_pre_link ()
{
+ int err;
if (main_class_name == NULL)
return 0;
input_filename = main_class_name;
input_filename_length = strlen (main_class_name);
- return do_spec (jvgenmain_spec);
+ err = do_spec (jvgenmain_spec);
+ if (err == 0)
+ {
+ /* Shift the outfiles array so the generated main comes first.
+ This is important when linking against (non-shared) libraries,
+ since otherwise we risk (a) nothing getting linked or
+ (b) 'main' getting picked up from a library. */
+ int i = n_infiles;
+ const char *generated = outfiles[i];
+ while (--i >= 0)
+ outfiles[i + 1] = outfiles[i];
+ outfiles[0] = generated;
+ }
+ return err;
}