summaryrefslogtreecommitdiff
path: root/gcc/java/jvgenmain.c
diff options
context:
space:
mode:
authortromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>2007-01-09 19:58:05 +0000
committertromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>2007-01-09 19:58:05 +0000
commit65bf3316cf384588453604be6b4f0ed3751a8b0f (patch)
tree996a5f57d4a68c53473382e45cb22f574cb3e4db /gcc/java/jvgenmain.c
parent8fc56618a84446beccd45b80381cdfe0e94050df (diff)
downloadgcc-65bf3316cf384588453604be6b4f0ed3751a8b0f.tar.gz
Merged gcj-eclipse branch to trunk.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@120621 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/java/jvgenmain.c')
-rw-r--r--gcc/java/jvgenmain.c30
1 files changed, 22 insertions, 8 deletions
diff --git a/gcc/java/jvgenmain.c b/gcc/java/jvgenmain.c
index e0cddc0d4d5..f4fb0ba38ab 100644
--- a/gcc/java/jvgenmain.c
+++ b/gcc/java/jvgenmain.c
@@ -1,5 +1,5 @@
/* Program to generate "main" a Java(TM) class containing a main method.
- Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005
+ Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006
Free Software Foundation, Inc.
This file is part of GCC.
@@ -57,14 +57,23 @@ main (int argc, char **argv)
FILE *stream;
const char *mangled_classname;
int i, last_arg;
+ int indirect = 0;
+ char *prog_name = argv[0];
/* Unlock the stdio streams. */
unlock_std_streams ();
gcc_init_libintl ();
+ if (argc > 1 && ! strcmp (argv[1], "-findirect-dispatch"))
+ {
+ indirect = 1;
+ ++argv;
+ --argc;
+ }
+
if (argc < 2)
- usage (argv[0]);
+ usage (prog_name);
for (i = 1; i < argc; ++i)
{
@@ -77,7 +86,7 @@ main (int argc, char **argv)
}
if (i < argc - 2 || i == argc)
- usage (argv[0]);
+ usage (prog_name);
last_arg = i;
classname = argv[i];
@@ -85,7 +94,7 @@ main (int argc, char **argv)
/* gcj always appends `main' to classname. We need to strip this here. */
p = strrchr (classname, 'm');
if (p == NULL || p == classname || strcmp (p, "main") != 0)
- usage (argv[0]);
+ usage (prog_name);
else
*p = '\0';
@@ -99,7 +108,7 @@ main (int argc, char **argv)
if (stream == NULL)
{
fprintf (stderr, _("%s: Cannot open output file: %s\n"),
- argv[0], outfile);
+ prog_name, outfile);
exit (1);
}
}
@@ -130,13 +139,18 @@ main (int argc, char **argv)
fprintf (stream, "int main (int argc, const char **argv)\n");
fprintf (stream, "{\n");
fprintf (stream, " _Jv_Compiler_Properties = props;\n");
- fprintf (stream, " extern void *%s;\n", mangled_classname);
- fprintf (stream, " JvRunMain (%s, argc, argv);\n", mangled_classname);
+ if (indirect)
+ fprintf (stream, " JvRunMainName (\"%s\", argc, argv);\n", classname);
+ else
+ {
+ fprintf (stream, " extern void *%s;\n", mangled_classname);
+ fprintf (stream, " JvRunMain (%s, argc, argv);\n", mangled_classname);
+ }
fprintf (stream, "}\n");
if (stream != stdout && fclose (stream) != 0)
{
fprintf (stderr, _("%s: Failed to close output file %s\n"),
- argv[0], argv[2]);
+ prog_name, argv[2]);
exit (1);
}
return 0;