scala.sys.ShutdownHookThread.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of spark-core Show documentation
Show all versions of spark-core Show documentation
Shaded version of Apache Spark 2.x.x for Presto
The newest version!
/* __ *\
** ________ ___ / / ___ Scala API **
** / __/ __// _ | / / / _ | (c) 2003-2013, LAMP/EPFL **
** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
** /____/\___/_/ |_/____/_/ | | **
** |/ **
\* */
package scala
package sys
/** A minimal Thread wrapper to enhance shutdown hooks. It knows
* how to unregister itself.
*
* @author Paul Phillips
* @version 2.9
* @since 2.9
*/
class ShutdownHookThread private (name: String) extends Thread(name) {
def remove() = runtime removeShutdownHook this
}
object ShutdownHookThread {
private var hookNameCount: Int = 0
private def hookName(): String = synchronized {
hookNameCount += 1
"shutdownHook" + hookNameCount
}
/** Creates, names, and registers a shutdown hook to run the
* given code.
*/
def apply(body: => Unit): ShutdownHookThread = {
val t = new ShutdownHookThread(hookName()) {
override def run() = body
}
runtime addShutdownHook t
t
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy