aboutsummaryrefslogtreecommitdiffstats
path: root/javac.in
diff options
context:
space:
mode:
Diffstat (limited to 'javac.in')
-rw-r--r--javac.in62
1 files changed, 62 insertions, 0 deletions
diff --git a/javac.in b/javac.in
new file mode 100644
index 0000000..4722273
--- /dev/null
+++ b/javac.in
@@ -0,0 +1,62 @@
+#!/usr/bin/perl -w
+use strict;
+use constant NO_DUP_ARGS => qw(-source -target -d -encoding);
+use constant STRIP_ARGS => qw(-Werror -implicit:none);
+
+my $ECJ_WARNINGS="-warn:-unused,-serial";
+my $JAVAC_WARNINGS="-Xlint:all,-serial";
+
+my @bcoption;
+push @bcoption, '-bootclasspath', glob '@abs_top_builddir@/bootstrap/jdk1.6.0/jre/lib/rt.jar'
+ unless grep {$_ eq '-bootclasspath'} @ARGV;
+my @ecj_parms = ($ECJ_WARNINGS, @bcoption);
+
+# Work around ecj's inability to handle duplicate command-line
+# options and unknown javac options.
+sub gen_ecj_opts
+{
+ my @new_args = @{$_[0]};
+
+ for my $opt (NO_DUP_ARGS)
+ {
+ my @indices = reverse grep {$new_args[$_] eq $opt} 0..$#new_args;
+ if (@indices > 1) {
+ shift @indices; # keep last instance only
+ splice @new_args, $_, 2 for @indices;
+ }
+ }
+
+ for my $opt (STRIP_ARGS)
+ {
+ my @indices = reverse grep {$new_args[$_] eq $opt} 0..$#new_args;
+ splice @new_args, $_, 1 for @indices;
+ }
+
+ return @new_args;
+}
+
+if ( -e "@abs_top_builddir@/native-ecj" )
+{
+ my @ecj_args = gen_ecj_opts( \@ARGV );
+ exec '@abs_top_builddir@/native-ecj', @ecj_parms, @ecj_args ;
+}
+elsif ( -e "@JAVAC@" )
+{
+ if ("@USING_ECJ@" eq "yes")
+ {
+ my @ecj_args = gen_ecj_opts( \@ARGV );
+ exec '@JAVAC@', @ecj_parms, @ecj_args ;
+ }
+ else
+ {
+ exec '@JAVAC@', $JAVAC_WARNINGS, @ARGV ;
+ }
+}
+else
+{
+ my @ecj_args = gen_ecj_opts( \@ARGV );
+ my @CLASSPATH = ('@ECJ_JAR@');
+ push @CLASSPATH, split /:/, $ENV{"CLASSPATH"} if exists $ENV{"CLASSPATH"};
+ $ENV{"CLASSPATH"} = join ':', @CLASSPATH;
+ exec '@JAVA@', 'org.eclipse.jdt.internal.compiler.batch.Main', @ecj_parms, @ecj_args;
+}