/**************************************************************************
* Parts copyright (c) 2001 by Punch Telematix. All rights reserved. *
* Parts copyright (c) 2005, 2008 by Chris Gray, /k/ Embedded Java *
* Solutions. 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. Neither the name of Punch Telematix or of /k/ Embedded Java Solutions*
* nor the names of other contributors may be used to endorse or promote*
* products derived from this software without specific prior written *
* permission. *
* *
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS 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 PUNCH TELEMATIX, /K/ EMBEDDED JAVA SOLUTIONS OR OTHER *
* 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. *
**************************************************************************/
package wonka.vm;
import java.io.IOException;
import java.io.OutputStream;
import java.io.InputStream;
public class NativeProcess extends Process {
private static final ProcessMonitor monitor = new ProcessMonitor();
private static final int LAUNCHING = 10001;
final static int STILL_RUNNING = 10000;
final static int ERROR = 10002;
private OutputStream out;
private InputStream in;
private InputStream err;
ProcessInfo info;
String[] cmdarray;
String[] envp;
String path;
int returnvalue;
Throwable exception;
public NativeProcess(String[] cmdarray, String[] envp, String string) throws IOException {
this.cmdarray = cmdarray;
this.envp = envp;
this.path = string;
returnvalue = LAUNCHING;
synchronized(this) {
NativeProcess.monitor.exec(this);
do {
try {
this.wait();
} catch (InterruptedException e) {
}
}while(returnvalue == LAUNCHING);
}
if(returnvalue == ERROR) {
if(exception instanceof RuntimeException) {
exception.fillInStackTrace();
throw (RuntimeException) exception;
}
throw new IOException(exception);
}
}
public synchronized OutputStream getOutputStream() {
if (out == null) {
out = new ProcessOutputStream(this);
}
return out;
}
public synchronized InputStream getInputStream() {
if(in == null) {
in = new ProcessInputStream(this, true);
}
return in;
}
public synchronized InputStream getErrorStream() {
if (err == null) {
err = new ProcessInputStream(this, false);
}
return err;
}
public synchronized int waitFor() throws InterruptedException {
while (returnvalue == STILL_RUNNING) {
this.wait();
}
if(returnvalue == ERROR) {
return -1;
}
else {
return returnvalue;
}
}
public int exitValue() throws IllegalThreadStateException {
if(returnvalue == STILL_RUNNING) {
throw new IllegalThreadStateException("Process is still running");
}
if(returnvalue == ERROR) {
return -1;
}
return returnvalue;
}
public void destroy() {
info.destroy();
}
public String toString() {
return "PID: " + (info == null ? "???" : String.valueOf(info.id)) + " returnvalue: " +
(returnvalue < STILL_RUNNING ? String.valueOf(returnvalue) : "?");
}
synchronized void setReturnValue(int returnValue) {
returnvalue = returnValue;
this.notifyAll();
}
}