mirror of https://github.com/sbt/sbt.git
Revert "explicitly close streams"
Revert "explicitly close streams on java.lang.Process to avoid descriptor leaks"
This reverts commit 3191eedf9e.
This commit is contained in:
parent
79caa03093
commit
0f3c75a2ea
|
|
@ -55,11 +55,6 @@ object BasicIO
|
||||||
final val BufferSize = 8192
|
final val BufferSize = 8192
|
||||||
final val Newline = System.getProperty("line.separator")
|
final val Newline = System.getProperty("line.separator")
|
||||||
|
|
||||||
def closeProcessStreams(p: JProcess): Unit =
|
|
||||||
Seq(p.getOutputStream, p.getInputStream, p.getErrorStream) foreach { s =>
|
|
||||||
if(s ne null) close(s)
|
|
||||||
}
|
|
||||||
|
|
||||||
def close(c: java.io.Closeable) = try { c.close() } catch { case _: java.io.IOException => () }
|
def close(c: java.io.Closeable) = try { c.close() } catch { case _: java.io.IOException => () }
|
||||||
def processFully(buffer: Appendable): InputStream => Unit = processFully(appendLine(buffer))
|
def processFully(buffer: Appendable): InputStream => Unit = processFully(appendLine(buffer))
|
||||||
def processFully(processLine: String => Unit): InputStream => Unit =
|
def processFully(processLine: String => Unit): InputStream => Unit =
|
||||||
|
|
@ -369,6 +364,8 @@ private[sbt] class DummyProcessBuilder(override val toString: String, exitValue
|
||||||
override def run(io: ProcessIO): Process = new DummyProcess(exitValue)
|
override def run(io: ProcessIO): Process = new DummyProcess(exitValue)
|
||||||
override def canPipeTo = true
|
override def canPipeTo = true
|
||||||
}
|
}
|
||||||
|
/** A thin wrapper around a java.lang.Process. `ioThreads` are the Threads created to do I/O.
|
||||||
|
* The implementation of `exitValue` waits until these threads die before returning. */
|
||||||
private class DummyProcess(action: => Int) extends Process
|
private class DummyProcess(action: => Int) extends Process
|
||||||
{
|
{
|
||||||
private[this] val exitCode = Future(action)
|
private[this] val exitCode = Future(action)
|
||||||
|
|
@ -402,23 +399,18 @@ private[sbt] class SimpleProcessBuilder(p: JProcessBuilder) extends AbstractProc
|
||||||
* returning. */
|
* returning. */
|
||||||
private class SimpleProcess(p: JProcess, inputThread: Thread, outputThreads: List[Thread]) extends Process
|
private class SimpleProcess(p: JProcess, inputThread: Thread, outputThreads: List[Thread]) extends Process
|
||||||
{
|
{
|
||||||
override def exitValue(): Int =
|
override def exitValue() =
|
||||||
{
|
{
|
||||||
andCleanup { p.waitFor() }// wait for the process to terminate
|
try { p.waitFor() }// wait for the process to terminate
|
||||||
|
finally { inputThread.interrupt() } // we interrupt the input thread to notify it that it can terminate
|
||||||
|
outputThreads.foreach(_.join()) // this ensures that all output is complete before returning (waitFor does not ensure this)
|
||||||
p.exitValue()
|
p.exitValue()
|
||||||
}
|
}
|
||||||
override def destroy() =
|
override def destroy() =
|
||||||
andCleanup { p.destroy() }
|
{
|
||||||
|
try { p.destroy() }
|
||||||
private[this] def andCleanup[T](action: => Unit): Unit =
|
finally { inputThread.interrupt() }
|
||||||
try
|
}
|
||||||
{
|
|
||||||
try { action }
|
|
||||||
finally { inputThread.interrupt() } // we interrupt the input thread to notify it that it can terminate
|
|
||||||
outputThreads.foreach(_.join()) // this ensures that all output is complete before returning (waitFor does not ensure this)
|
|
||||||
}
|
|
||||||
finally
|
|
||||||
BasicIO.closeProcessStreams(p)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private class FileOutput(file: File, append: Boolean) extends OutputStreamBuilder(new FileOutputStream(file, append), file.getAbsolutePath)
|
private class FileOutput(file: File, append: Boolean) extends OutputStreamBuilder(new FileOutputStream(file, append), file.getAbsolutePath)
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue