問題は、InputStreamのみを読み取っており、ErrorStreamを読み取っていないことだと思います。また、両方のストリームが並行して読み取られるように注意する必要があります。現在、出力ストリームからパイプされたデータがOSバッファーをいっぱいにした場合、リーダーにバッファーを空にする機会を与えるために、execコマンドが自動的に一時停止されることがあります。ただし、プログラムは出力が処理されるのをまだ待機しています。したがって、ハングが発生します。
次のように、入力ストリームとエラーストリームの両方を処理する別のクラスを作成できます。
public class ReadStream implements Runnable {
String name;
InputStream is;
Thread thread;
public ReadStream(String name, InputStream is) {
this.name = name;
this.is = is;
}
public void start () {
thread = new Thread (this);
thread.start ();
}
public void run () {
try {
InputStreamReader isr = new InputStreamReader (is);
BufferedReader br = new BufferedReader (isr);
while (true) {
String s = br.readLine ();
if (s == null) break;
System.out.println ("[" + name + "] " + s);
}
is.close ();
} catch (Exception ex) {
System.out.println ("Problem reading stream " + name + "... :" + ex);
ex.printStackTrace ();
}
}
}
使い方は次のとおりです。
String cmd= "cmd /C si viewhistory --fields=revision --project="+fileName;
Process p = Runtime.getRuntime().exec(cmd) ;
s1 = new ReadStream("stdin", p.getInputStream ());
s2 = new ReadStream("stderr", p.getErrorStream ());
s1.start ();
s2.start ();
p.waitFor();
} catch (Exception e) {
e.printStackTrace();
} finally {
if(p != null)
p.destroy();
}