Skip to content

Commit

Permalink
Start the PC thread only after initialization of required symbols.
Browse files Browse the repository at this point in the history
If the class path is incomplete, the presentation compiler might crash during construction.
If the PC thread was already started, it will never get the chance to shutdown, and the
thread leaks. In the IDE, where the PC is started when needed, this can lead to a very
quick depletion of JVM threads.

See Scala IDE #1002016.
  • Loading branch information
dragos authored and retronym committed Feb 10, 2014
1 parent ea36cad commit 894aee1
Showing 1 changed file with 12 additions and 3 deletions.
15 changes: 12 additions & 3 deletions src/interactive/scala/tools/nsc/interactive/Global.scala
Original file line number Diff line number Diff line change
Expand Up @@ -534,7 +534,6 @@ class Global(settings: Settings, _reporter: Reporter, projectName: String = "")
threadId += 1
compileRunner = new PresentationCompilerThread(this, projectName)
compileRunner.setDaemon(true)
compileRunner.start()
compileRunner
}

Expand Down Expand Up @@ -1252,11 +1251,21 @@ class Global(settings: Settings, _reporter: Reporter, projectName: String = "")

forceSymbolsUsedByParser()

/** Start the compiler background thread and turn on thread confinement checks */
private def finishInitialization(): Unit = {
// this flag turns on `assertCorrectThread checks`
initializing = false

// Only start the thread if initialization was successful. A crash while forcing symbols (for example
// if the Scala library is not on the classpath) can leave running threads behind. See Scala IDE #1002016
compileRunner.start()
}

/** The compiler has been initialized. Constructors are evaluated in textual order,
* so this is set to true only after all super constructors and the primary constructor
* if we reached here, all super constructors and the primary constructor
* have been executed.
*/
initializing = false
finishInitialization()
}

object CancelException extends Exception

0 comments on commit 894aee1

Please sign in to comment.