You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@tomcat.apache.org by co...@apache.org on 2001/05/28 05:01:20 UTC
cvs commit: jakarta-tomcat-jasper/jasper34/generator/org/apache/jasper34/javacompiler JavaCompiler.java JikesJavaCompiler.java SunJavaCompiler.java
costin 01/05/27 20:01:20
Added: jasper34/generator/org/apache/jasper34/javacompiler
JavaCompiler.java JikesJavaCompiler.java
SunJavaCompiler.java
Log:
The javac part.
Revision Changes Path
1.1 jakarta-tomcat-jasper/jasper34/generator/org/apache/jasper34/javacompiler/JavaCompiler.java
Index: JavaCompiler.java
===================================================================
/*
* ====================================================================
*
* The Apache Software License, Version 1.1
*
* Copyright (c) 1999 The Apache Software Foundation. All rights
* reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* 3. The end-user documentation included with the redistribution, if
* any, must include the following acknowlegement:
* "This product includes software developed by the
* Apache Software Foundation (http://www.apache.org/)."
* Alternately, this acknowlegement may appear in the software itself,
* if and wherever such third-party acknowlegements normally appear.
*
* 4. The names "The Jakarta Project", "Tomcat", and "Apache Software
* Foundation" must not be used to endorse or promote products derived
* from this software without prior written permission. For written
* permission, please contact apache@apache.org.
*
* 5. Products derived from this software may not be called "Apache"
* nor may "Apache" appear in their names without prior written
* permission of the Apache Group.
*
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
* ====================================================================
*
* This software consists of voluntary contributions made by many
* individuals on behalf of the Apache Software Foundation. For more
* information on the Apache Software Foundation, please see
* <http://www.apache.org/>.
*
*/
package org.apache.jasper34.javacompiler;
import java.io.OutputStream;
/**
* If you want to plugin your own Java compiler, you probably want to
* write a class that implements this interface.
*
* @author Anil K. Vijendran
* @author Sam Ruby
*/
public interface JavaCompiler {
/**
* Specify where the compiler can be found
*/
void setCompilerPath(String compilerPath);
/**
* Set the encoding (character set) of the source
*/
void setEncoding(String encoding);
/**
* Set the class path for the compiler
*/
void setClasspath(String classpath);
/**
* Set the output directory
*/
void setOutputDir(String outdir);
/**
* Set where you want the compiler output (messages) to go
*/
void setMsgOutput(OutputStream out);
/**
* Set if you want debugging information in the class file
*/
void setClassDebugInfo(boolean classDebugInfo);
/**
* Execute the compiler
* @param source - file name of the source to be compiled
*/
boolean compile(String source);
}
1.1 jakarta-tomcat-jasper/jasper34/generator/org/apache/jasper34/javacompiler/JikesJavaCompiler.java
Index: JikesJavaCompiler.java
===================================================================
/*
* ====================================================================
*
* The Apache Software License, Version 1.1
*
* Copyright (c) 1999 The Apache Software Foundation. All rights
* reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* 3. The end-user documentation included with the redistribution, if
* any, must include the following acknowlegement:
* "This product includes software developed by the
* Apache Software Foundation (http://www.apache.org/)."
* Alternately, this acknowlegement may appear in the software itself,
* if and wherever such third-party acknowlegements normally appear.
*
* 4. The names "The Jakarta Project", "Tomcat", and "Apache Software
* Foundation" must not be used to endorse or promote products derived
* from this software without prior written permission. For written
* permission, please contact apache@apache.org.
*
* 5. Products derived from this software may not be called "Apache"
* nor may "Apache" appear in their names without prior written
* permission of the Apache Group.
*
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
* ====================================================================
*
* This software consists of voluntary contributions made by many
* individuals on behalf of the Apache Software Foundation. For more
* information on the Apache Software Foundation, please see
* <http://www.apache.org/>.
*
*/
package org.apache.jasper34.javacompiler;
import java.io.BufferedInputStream;
import java.io.OutputStream;
import java.io.IOException;
import java.io.File;
import java.io.ByteArrayOutputStream;
/**
* A Plug-in class for specifying a 'jikes' compile.
*
* @author Jeffrey Chiu
* @author Hans Bergsten <ha...@gefionsoftware.com>
*/
public class JikesJavaCompiler implements JavaCompiler {
static final int OUTPUT_BUFFER_SIZE = 1024;
static final int BUFFER_SIZE = 512;
static final String q =
"\\".equals(System.getProperty("file.separator")) ? "\"" : "";
/*
* Contains extra classpath for Jikes use from Microsoft systems:
* Microsoft does not report it's internal classpath in
* System.getProperty(java.class.path) which results in jikes to fail.
* (Internal classpath with other JVMs contains for instance rt.jar).
*/
static StringBuffer MicrosoftClasspath = null;
String encoding;
String classpath;
String compilerPath = "jikes";
String outdir;
OutputStream out;
boolean classDebugInfo=false;
/**
* Specify where the compiler can be found
*/
public void setCompilerPath(String compilerPath) {
this.compilerPath = compilerPath;
}
/**
* Set the encoding (character set) of the source
*/
public void setEncoding(String encoding) {
this.encoding = encoding;
}
/**
* Set the class path for the compiler
*/
public void setClasspath(String classpath) {
this.classpath = classpath;
}
/**
* Set the output directory
*/
public void setOutputDir(String outdir) {
this.outdir = outdir;
}
/**
* Set where you want the compiler output (messages) to go
*/
public void setMsgOutput(OutputStream out) {
this.out = out;
}
/**
* Set if you want debugging information in the class file
*/
public void setClassDebugInfo(boolean classDebugInfo) {
this.classDebugInfo = classDebugInfo;
}
/**
* Execute the compiler
* @param source - file name of the source to be compiled
*/
public boolean compile(String source) {
Process p;
int exitValue = -1;
// Used to dynamically load classpath if using Microsoft
// virtual machine
if (MicrosoftClasspath==null) {
MicrosoftClasspath = new StringBuffer(200);
if (System.getProperty("java.vendor").startsWith("Microsoft")) {
//Get Microsoft classpath
String javaHome = System.getProperty("java.home") +
"\\Packages";
File libDir=new File(javaHome);
String[] zips=libDir.list();
for(int i=0;i<zips.length;i++) {
MicrosoftClasspath.append(";" + javaHome + "\\" + zips[i]);
}
}
}
String[] compilerCmd;
if (classDebugInfo) {
compilerCmd = new String[] {
q + compilerPath + q,
"-g",
//XXX - add encoding once Jikes supports it
"-classpath", q + classpath + MicrosoftClasspath + q,
"-d", q + outdir + q,
"-nowarn",
q + source + q
};
} else {
compilerCmd = new String[] {
q + compilerPath + q,
//XXX - add encoding once Jikes supports it
"-classpath", q + classpath + MicrosoftClasspath + q,
"-d", q + outdir + q,
"-nowarn",
q + source + q
};
}
ByteArrayOutputStream tmpErr = new ByteArrayOutputStream(OUTPUT_BUFFER_SIZE);
try {
p = Runtime.getRuntime().exec(compilerCmd);
BufferedInputStream compilerErr = new
BufferedInputStream(p.getErrorStream());
StreamPumper errPumper = new StreamPumper(compilerErr, tmpErr);
errPumper.start();
p.waitFor();
exitValue = p.exitValue();
// Wait until the complete error stream has been read
errPumper.join();
compilerErr.close();
p.destroy();
// Write the compiler error messages, if any, to the real stream
tmpErr.close();
tmpErr.writeTo(out);
} catch (IOException ioe) {
return false;
} catch (InterruptedException ie) {
return false;
}
boolean isOkay = exitValue == 0;
// Jikes returns 0 even when there are some types of errors.
// Check if any error output as well
if (tmpErr.size() > 0) {
isOkay = false;
}
return isOkay;
}
// Inner class for continually pumping the input stream during
// Process's runtime.
class StreamPumper extends Thread {
private BufferedInputStream stream;
private boolean endOfStream = false;
private boolean stopSignal = false;
private int SLEEP_TIME = 5;
private OutputStream out;
public StreamPumper(BufferedInputStream is, OutputStream out) {
this.stream = is;
this.out = out;
}
public void pumpStream()
throws IOException
{
byte[] buf = new byte[BUFFER_SIZE];
if (!endOfStream) {
int bytesRead=stream.read(buf, 0, BUFFER_SIZE);
if (bytesRead > 0) {
out.write(buf, 0, bytesRead);
} else if (bytesRead==-1) {
endOfStream=true;
}
}
}
public void run() {
try {
//while (!endOfStream || !stopSignal) {
while (!endOfStream) {
pumpStream();
sleep(SLEEP_TIME);
}
} catch (InterruptedException ie) {
} catch (IOException ioe) {
}
}
}
}
1.1 jakarta-tomcat-jasper/jasper34/generator/org/apache/jasper34/javacompiler/SunJavaCompiler.java
Index: SunJavaCompiler.java
===================================================================
/*
* ====================================================================
*
* The Apache Software License, Version 1.1
*
* Copyright (c) 1999 The Apache Software Foundation. All rights
* reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* 3. The end-user documentation included with the redistribution, if
* any, must include the following acknowlegement:
* "This product includes software developed by the
* Apache Software Foundation (http://www.apache.org/)."
* Alternately, this acknowlegement may appear in the software itself,
* if and wherever such third-party acknowlegements normally appear.
*
* 4. The names "The Jakarta Project", "Tomcat", and "Apache Software
* Foundation" must not be used to endorse or promote products derived
* from this software without prior written permission. For written
* permission, please contact apache@apache.org.
*
* 5. Products derived from this software may not be called "Apache"
* nor may "Apache" appear in their names without prior written
* permission of the Apache Group.
*
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
* ====================================================================
*
* This software consists of voluntary contributions made by many
* individuals on behalf of the Apache Software Foundation. For more
* information on the Apache Software Foundation, please see
* <http://www.apache.org/>.
*
*/
package org.apache.jasper34.javacompiler;
import java.io.OutputStream;
import sun.tools.javac.Main;
/**
* The default compiler. This is the javac present in JDK 1.1.x and
* JDK 1.2.
*
* At some point we need to make sure there is a class like this for
* JDK 1.3, and other javac-like animals that people want to use.
*
* @author Anil K. Vijendran
*/
public class SunJavaCompiler implements JavaCompiler {
String encoding;
String classpath; // ignored
String compilerPath;
String outdir;
OutputStream out;
boolean classDebugInfo=false;
/**
* Specify where the compiler can be found
*/
public void setCompilerPath(String compilerPath) {
// not used by the SunJavaCompiler
this.compilerPath = compilerPath;
}
/**
* Set the encoding (character set) of the source
*/
public void setEncoding(String encoding) {
this.encoding = encoding;
}
/**
* Set the class path for the compiler
*/
public void setClasspath(String classpath) {
this.classpath = classpath;
}
/**
* Set the output directory
*/
public void setOutputDir(String outdir) {
this.outdir = outdir;
}
/**
* Set where you want the compiler output (messages) to go
*/
public void setMsgOutput(OutputStream out) {
this.out = out;
}
/**
* Set where you want the compiler output (messages) to go
*/
public void setOut(OutputStream out) {
this.out = out;
}
/**
* Set if you want debugging information in the class file
*/
public void setClassDebugInfo(boolean classDebugInfo) {
this.classDebugInfo = classDebugInfo;
}
public boolean compile(String source) {
Main compiler = new Main(out, "jsp->javac");
String[] args;
if (classDebugInfo) {
args = new String[]
{
"-g",
"-encoding", encoding,
"-classpath", classpath,
"-d", outdir,
source
};
} else {
args = new String[]
{
"-encoding", encoding,
"-classpath", classpath,
"-d", outdir,
source
};
}
return compiler.compile(args);
}
}