Wait for stream reading threads to finish when awaiting CLI invocation
Closes gh-2787 (I hope)
This commit is contained in:
parent
83f842a226
commit
0141f50ec8
|
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
* Copyright 2012-2014 the original author or authors.
|
||||
* Copyright 2012-2015 the original author or authors.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
|
|
@ -92,12 +92,17 @@ public final class CommandLineInvoker {
|
|||
|
||||
private final Process process;
|
||||
|
||||
private final List<Thread> streamReaders = new ArrayList<Thread>();
|
||||
|
||||
public Invocation(Process process) {
|
||||
this.process = process;
|
||||
new Thread(new StreamReadingRunnable(this.process.getErrorStream(), this.err))
|
||||
.start();
|
||||
new Thread(new StreamReadingRunnable(this.process.getInputStream(), this.out))
|
||||
.start();
|
||||
this.streamReaders.add(new Thread(new StreamReadingRunnable(this.process
|
||||
.getErrorStream(), this.err)));
|
||||
this.streamReaders.add(new Thread(new StreamReadingRunnable(this.process
|
||||
.getInputStream(), this.out)));
|
||||
for (Thread streamReader : this.streamReaders) {
|
||||
streamReader.start();
|
||||
}
|
||||
}
|
||||
|
||||
public String getErrorOutput() {
|
||||
|
|
@ -140,6 +145,9 @@ public final class CommandLineInvoker {
|
|||
}
|
||||
|
||||
public int await() throws InterruptedException {
|
||||
for (Thread streamReader : this.streamReaders) {
|
||||
streamReader.join();
|
||||
}
|
||||
return this.process.waitFor();
|
||||
}
|
||||
|
||||
|
|
@ -171,6 +179,7 @@ public final class CommandLineInvoker {
|
|||
// Allow thread to die
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue