diff --git a/ghc/driver/ghc.lprl b/ghc/driver/ghc.lprl
index 8f7cb9eee4c78555f90c369bd3f389f3bcaf818f..34db5eb06a9b6b48ec5e1491b0ae1962d4812b81 100644
--- a/ghc/driver/ghc.lprl
+++ b/ghc/driver/ghc.lprl
@@ -462,11 +462,15 @@ $PostprocessCcOutput = 0;
 $Static = 1;
 $Static = 0 if ($EnableWin32DLLs eq 'YES');
 
-# native code-gen or via C?
+# Output language
 $HaveNativeCodeGen = $GhcWithNativeCodeGen;
-$HscOut = '-C='; # '-C=' ==> .hc output; '-S=' ==> .s output; '-N=' ==> neither
-$HscOut = '-S='
+$HscLang = 'C'; 	# 'C'    ==> .hc output; 
+			# 'asm'  ==> .s output; 
+			# 'java' ==> .java output
+			# 'none' ==> no code output
+$HscLang = 'asm'
     if ($HaveNativeCodeGen ne 'YES') && $TargetPlatform =~ /^(alpha)-/;
+
 # TEMP: disable x86 & Sparc if $HaveNativeCodeGen && $TargetPlatform =~ /^(i386|alpha|sparc)-/;
 $ProduceHi    = '-hifile=';
 $HiOnStdout   = 0;
@@ -942,9 +946,9 @@ After the sanity checks, add flags to the necessary parts of the driver pipeline
   if ( $BuildTag ne '' ) { # something other than normal sequential...
 
       local($Tag) = "${BuildTag}";
-      $Tag =~ s/_//;  # move the underscore to the back
+      $Tag =~ s/_//;	# move the underscore to the back
 
-      $HscOut = '-C='; # must go via C
+      $HscLang = 'C'; 	# must go via C
       &processArgs(split(' ', $SetupOpts{$BuildTag}));
 #      eval($EvaldSetupOpts{$BuildTag});
   }
@@ -1401,11 +1405,17 @@ Again, we'll do the post-recompilation-checker parts of this later.
     # 
     local($do_cc)	= ( $Do_cc != -1) # i.e., it was set explicitly
 			  ? $Do_cc
-			  : ( ($HscOut eq '-C=') ? 1 : 0 );
+			  : ( ($HscLang eq 'C') ? 1 : 0 );
     local($do_as)	= $Do_as;
-    local($hsc_out)	   = ( $HscOut eq '-C=' ) ? "$Tmp_prefix.hc" : "$Tmp_prefix.s" ;
-    local($hsc_out_c_stub) = ( $HscOut eq '-C=' ) ? "${Tmp_prefix}_stb.c" : "";
-    local($hsc_out_h_stub) = ( $HscOut eq '-C=' ) ? "${Tmp_prefix}_stb.h" : "";
+
+    local($hsc_out_suffix) = ( $HscLang eq 'C' )    ? "hc" : 
+			     ( $HscLang eq 'asm' )  ? "s" : 
+			     ( $HscLang eq 'java' ) ? "java" : 
+				"" ;
+    
+    local($hsc_out) 	   = $Tmp_prefix.$hsc_out_suffix ;
+    local($hsc_out_c_stub) = ( $HscLang eq 'C' ) ? "${Tmp_prefix}_stb.c" : "";
+    local($hsc_out_h_stub) = ( $HscLang eq 'C' ) ? "${Tmp_prefix}_stb.h" : "";
 
     if ($Only_preprocess_hc) { # stop after having run $Cc -E
        $do_as=0;
@@ -1445,20 +1455,20 @@ not} going to run, set its input (i.e., the output of its preceding
 phase) to @"$ifile_root.<suffix>"@.
 
 \begin{code}
-    local($going_interactive) = $HscOut eq '-N=' || $ifile_root eq '_stdin';
+    local($going_interactive) = $HscLang eq 'none' || $ifile_root eq '_stdin';
 
     #
     # Warning issued if -keep-hc-file-too is used without
     # -fvia-C (or the equivalent)
     #
-    if ( $HscOut ne '-C=' && $Keep_hc_file_too ) {
+    if ( $HscLang ne 'C' && $Keep_hc_file_too ) {
 	print STDERR "$Pgm: warning: Native code generator to be used, -keep-hc-file-too will be ignored\n";
     }
 
     if (! $do_cc && ! $do_as) { # stopping after hsc
 	$hsc_out = ($Specific_output_file ne '')
 		 ? $Specific_output_file
-		 : &odir_ify($ifile_root, ($HscOut eq '-C=') ? 'hc' : 's');
+		 : &odir_ify($ifile_root, $hsc_out_suffix);
 
 	$ofile_target = $hsc_out; # reset
     }
@@ -1673,7 +1683,7 @@ sub runHscAndProcessInterfaces {
 	# recompiling this module has been done
 	#
 	&run_something("touch $ofile_target",
-		       "Touch $ofile_target,  to propagate dependencies") if $HscOut ne '-N=';
+		       "Touch $ofile_target,  to propagate dependencies") if $HscLang ne 'none';
 
     } else {	
 
@@ -1682,18 +1692,20 @@ sub runHscAndProcessInterfaces {
     	# If non-interactive, heave in the consistency info at the end
     	# NB: pretty hackish (depends on how $output is set)
     	if ( ! $going_interactive ) {
-	    if ( $HscOut eq '-C=' ) {
-	    $to_do = "echo 'static char ghc_hsc_ID[] = \"\@(#)hsc $ifile\t$HsC_major_version.$HsC_minor_version,$HsC_consist_options\";' >> $hsc_out";
+	    if ( $HscLang eq 'C' ) {
+	         $to_do = "echo 'static char ghc_hsc_ID[] = \"\@(#)hsc $ifile\t$HsC_major_version.$HsC_minor_version,$HsC_consist_options\";' >> $hsc_out";
     
-	    } elsif ( $HscOut eq '-S=' ) {
+	        &run_something($to_do, 'Pin on Haskell consistency info');	
+	    } elsif ( $HscLang eq 'asm' ) {
 		local($consist) = "hsc.$ifile.$HsC_major_version.$HsC_minor_version.$HsC_consist_options";
 		$consist =~ s/,/./g;
 		$consist =~ s/\//./g;
 		$consist =~ s/-/_/g;
 		$consist =~ s/[^A-Za-z0-9_.]/ZZ/g; # ToDo: properly?
 		$to_do = "echo '\n\t.text\n$consist:' >> $hsc_out";
+		&run_something($to_do, 'Pin on Haskell consistency info');	
 	    }
-	    &run_something($to_do, 'Pin on Haskell consistency info');	
+ 	    # no consistency info for Java output files
     	}   
 
 
@@ -1704,12 +1716,12 @@ sub runHscAndProcessInterfaces {
 	}
 	# if we're going to split up object files,
 	# we inject split markers into the .hc file now
-	if ( $HscOut eq '-C=' && $SplitObjFiles ) {
+	if ( $HscLang eq 'C' && $SplitObjFiles ) {
 	    &inject_split_markers ( $hsc_out );
         }
 
 	# save a copy of the .hc file, even if we are carrying on...
-	if ($HscOut eq '-C=' && $do_cc && $Keep_hc_file_too) {
+	if ($HscLang eq 'C' && $do_cc && $Keep_hc_file_too) {
             &saveIntermediate($ifile_root , "hc" , $hsc_out);
 	}
 
@@ -1738,7 +1750,8 @@ sub runHsc {
 
     # set up for producing output/.hi; note that flag twiddling
     # may mean that nothing will actually be produced:
-    $output = "$ProduceHi$hsc_hi $HscOut$hsc_out -F=$hsc_out_c_stub -FH=$hsc_out_h_stub";
+    $oflags = ( $HscLang eq 'none' ? "" : "-olang=$HscLang -ofile=$hsc_out" ) ;
+    $output = "$ProduceHi$hsc_hi $oflags -F=$hsc_out_c_stub -FH=$hsc_out_h_stub";
     push(@Files_to_tidy, $hsc_hi, $hsc_out, $hsc_out_c_stub, $hsc_out_h_stub );
 
     # if we're compiling foo.hs, we want the GC stats to end up in foo.stat
@@ -2880,11 +2893,15 @@ arg: while($_ = $Args[0]) {
     # change the global default:
     # we won't run cat; we'll run the real thing
 	
-    /^-C$/	    && do { $Do_cc = 0; $Do_as = 0; $Do_lnkr = 0; $HscOut = '-C=';
+    /^-C$/	    && do { $Do_cc = 0; $Do_as = 0; $Do_lnkr = 0; $HscLang = 'C';
 			    next arg; };
     # stop after generating C
 	
-    /^-noC$/	    && do { $HscOut = '-N='; $ProduceHi = '-nohifile=';
+    /^-J$/	    && do { $Do_cc = 0; $Do_as = 0; $Do_lnkr = 0; $HscLang = 'java';
+			    next arg; };
+    # stop after generating Java
+	
+    /^-noC$/	    && do { $HscLang = 'none'; $ProduceHi = '-nohifile=';
 			    $Do_cc = 0; $Do_as = 0; $Do_lnkr = 0;
 			    next arg; };
     # leave out actual C generation (debugging) [also turns off interface gen]
@@ -3162,7 +3179,7 @@ arg: while($_ = $Args[0]) {
 			    print STDERR "WARNING: don't know how to split objects on this platform: $TargetPlatform\n`-split-objs' option ignored\n";
 			} else {
 			    $SplitObjFiles = 1;
-    			    $HscOut = '-C=';
+    			    $HscLang = 'C';
 
 			    push(@HsC_flags, "-fglobalise-toplev-names"); 
 			    push(@CcBoth_flags, '-DUSE_SPLIT_MARKERS');
@@ -3218,8 +3235,8 @@ arg: while($_ = $Args[0]) {
 
     # ---------------
 
-    /^-fasm-(.*)$/  	&& do { $HscOut = '-S='; next arg; }; # force using nativeGen
-    /^-fvia-[cC]$/	&& do { $HscOut = '-C='; next arg; }; # force using C compiler
+    /^-fasm-(.*)$/  	&& do { $HscLang = 'asm'; next arg; }; # force using nativeGen
+    /^-fvia-[cC]$/	&& do { $HscLang = 'C';   next arg; }; # force using C compiler
 
     # ---------------
 
@@ -3391,7 +3408,7 @@ arg: while($_ = $Args[0]) {
 		local($opt_lev) = ( /^-O2$/ ) ? 2 : 1; # max 'em
 		$OptLevel = ( $opt_lev > $OptLevel ) ? $opt_lev : $OptLevel;
 
-		$HscOut = '-C=' if $OptLevel == 2; # force use of C compiler
+		$HscLang = 'C' if $OptLevel == 2; # force use of C compiler
 		next arg; };
 
     /^-Onot$/	&& do { $OptLevel = 0; next arg; }; # # set it to <no opt>