|
Scala example source code file (ActorTask.scala)
The Scala ActorTask.scala source code/* __ *\ ** ________ ___ / / ___ Scala API ** ** / __/ __// _ | / / / _ | (c) 2005-2011, LAMP/EPFL ** ** __\ \/ /__/ __ |/ /__/ __ | ** ** /____/\___/_/ |_/____/_/ | | ** ** |/ ** \* */ package scala.actors /** * @author Philipp Haller */ private[actors] class ActorTask(actor: Actor, fun: () => Unit, handler: PartialFunction[Any, Any], msg: Any) extends ReplyReactorTask(actor, fun, handler, msg) { protected override def beginExecution() { super.beginExecution() actor.synchronized { // shouldExit guarded by actor if (actor.shouldExit) actor.exit() } } protected override def terminateExecution(e: Throwable) { val senderInfo = try { Some(actor.sender) } catch { case _: Exception => None } val uncaught = UncaughtException(actor, if (msg != null) Some(msg) else None, senderInfo, Thread.currentThread, e) val todo = actor.synchronized { if (!actor.links.isEmpty) actor.exitLinked(uncaught) else { super.terminateExecution(e) () => {} } } todo() } } Other Scala examples (source code examples)Here is a short list of links related to this Scala ActorTask.scala source code file: |
... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2021 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.