|
Scala example source code file (ActorTask.scala)
The ActorTask.scala Scala example source code/* __ *\ ** ________ ___ / / ___ Scala API ** ** / __/ __// _ | / / / _ | (c) 2005-2013, LAMP/EPFL ** ** __\ \/ /__/ __ |/ /__/ __ | ** ** /____/\___/_/ |_/____/_/ | | ** ** |/ ** \* */ package scala.actors /** * @author Philipp Haller * @note This class inherits a public var called 'msg' from ReactorTask, * and also defines a constructor parameter which shadows it (which makes any * changes to the underlying var invisible.) I can't figure out what's supposed * to happen, so I renamed the constructor parameter to at least be less confusing. */ private[actors] class ActorTask(actor: InternalActor, fun: () => Unit, handler: PartialFunction[Any, Any], initialMsg: Any) extends ReplyReactorTask(actor, fun, handler, initialMsg) { 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.internalSender) } catch { case _: Exception => None } // !!! If this is supposed to be setting the current contents of the // inherited mutable var rather than always the value given in the constructor, // then it should be changed from initialMsg to msg. val uncaught = UncaughtException(actor, if (initialMsg != null) Some(initialMsg) else None, senderInfo, Thread.currentThread, e) val todo = actor.synchronized { val res = if (!actor.links.isEmpty) actor.exitLinked(uncaught) else { super.terminateExecution(e) () => {} } res } todo() } } Other Scala source code examplesHere 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-2024 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.