Packages

  • package root
    Definition Classes
    root
  • package gopher

    Provides scala API for 'go-like' CSP channels.

    Provides scala API for 'go-like' CSP channels.

    Overview

    see readme for quick introduction.

    Usage

    At first you must receive gopherApi as Akka extension:

    import gopher._
    
    .....
    val gopherApi = Gopher(actorSystem)

    Then you can use CPS channels with blocling operations inside go clauses:

    val channel = gopherApi.makeChannel[Long]
    val n = 10000
    val producer = go {
     @volatile var(x,y) = (0L,1L)
     for( s <- gopherApi.select.forever) {
       case z: channel.write if (z==x) =>
                  x = y
                  y = x+z
                  if (x > n) {
                     channel.close
                     implicitly[FlowTermination[Unit]].doExit()
                  }
     }
    }
    val consumer = for((c,i) <- channel.zip(1 to n)) {
       Console.println(s"fib(${i})=${c}")
    }
    Await.ready(consumer, 10 seconds)

    and defer/recover in go/goScope

    goScope{
      val f = openFile(myFileName)
      defer{
        if (! recover{case ex:FileNotFoundException => Console.println("invalid fname")}) {
           f.close()
        }
      }
    }
    Definition Classes
    root
    See also

    gopher.GopherAPI

    gopher.channels.Channel

    gopher.channels.Input

    gopher.channels.Output

    gopher.channels.SelectorBuilder

    gopher.channels.SelectFactory

  • package transputers

    transputers implementations

    transputers implementations

    Definition Classes
    gopher
    See also

    gopher.transputers.TransputerSupervisor

    gopher.transputers.ReplicatedTransputer

  • abstract class ReplicatedTransputer[T <: Transputer, Self] extends ParTransputer

    Replicated[X] is transputer which keep n instances of X where ports of replicated consumer are connected to appropriative ports of instances in parallel.

    Replicated[X] is transputer which keep n instances of X where ports of replicated consumer are connected to appropriative ports of instances in parallel.

    Definition Classes
    transputers
    See also

    gopher.GopherAPI#replicate

  • InPort
  • InPortWithAdapter
  • OutPort
  • OutPortWithAdapter
  • SelectorRunner

class SelectorRunner extends SelectTransputer

Linear Supertypes
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. SelectorRunner
  2. SelectTransputer
  3. Transputer
  4. ForeverSelectorBuilder
  5. SelectorBuilder
  6. AnyRef
  7. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. Protected

Instance Constructors

  1. new SelectorRunner(configFun: (ForeverSelectorBuilder) => Unit)

Type Members

  1. class InPort[A] extends Input[A]
    Definition Classes
    Transputer
  2. class OutPort[A] extends Output[A]
    Definition Classes
    Transputer
  3. type timeout = FiniteDuration
    Definition Classes
    SelectorBuilder

Value Members

  1. object InPort
    Definition Classes
    Transputer
  2. object OutPort
    Definition Classes
    Transputer
  3. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. final def ##: Int
    Definition Classes
    AnyRef → Any
  5. def +(p: Transputer): ParTransputer
    Definition Classes
    Transputer
  6. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  7. def api: GopherAPI
    Definition Classes
    SelectorRunnerTransputerSelectorBuilder
  8. macro def apply(f: PartialFunction[Any, Unit]): Future[Unit]

    provide syntax for running select loop as async operation.

    provide syntax for running select loop as async operation.

    val receiver = gopherApi.select.forever{
                     case x: channel.read => Console.println(s"received:$x")
                   }
    Definition Classes
    ForeverSelectorBuilder
  9. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  10. def clone(): AnyRef
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.CloneNotSupportedException]) @native() @HotSpotIntrinsicCandidate()
  11. def copyPorts(prev: Transputer): Unit

    copy conection from previous instance when transputer is restarted.

    copy conection from previous instance when transputer is restarted.

    Definition Classes
    Transputer
  12. def copyState(prev: Transputer): Unit

    copyState from previous instance when transputer is restarted.

    copyState from previous instance when transputer is restarted. can be overriden in subclasses (by default: do nothing)

    Note, that port connection is restored before call of copyState

    Definition Classes
    Transputer
  13. implicit def ec: ExecutionContext
    Definition Classes
    SelectorBuilder
  14. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  15. def equals(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef → Any
  16. def failureLimit(maxFailures: Int = recoveryLimits.maxFailures, windowDuration: Duration = recoveryLimits.windowDuration): SelectorRunner.this.type

    set failure limit.

    set failure limit. (when number of failures during windowsDuration is bigger than maxFailures, TooManyFailures exception is escalated to parent transputer.

    Definition Classes
    Transputer
  17. macro def foreach(f: (Any) => Unit): Unit

    provide syntax for running select loop inside go (or async) block example of usage:

    provide syntax for running select loop inside go (or async) block example of usage:

    go {
      .....
      for(s <- gopherApi.select.forever)
        s match {
          case x: ch1.read => do something with x
          case q: chq.read => implicitly[FlowTermination[Unit]].doExit(())
          case y: ch2.write if (y=expr) => do something with y
          case _ => do somethig when idle.
        }

    Note, that you can use implicit instance of [FlowTermination[Unit]] to stop loop.

    Definition Classes
    ForeverSelectorBuilder
  18. def futureInput[A](f: Future[A]): FutureInput[A]
    Definition Classes
    SelectorBuilder
    Annotations
    @inline()
  19. final def getClass(): Class[_ <: AnyRef]
    Definition Classes
    AnyRef → Any
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  20. final def go: Future[Unit]
    Definition Classes
    SelectorBuilder
  21. def goOnce: Future[Unit]
    Definition Classes
    SelectTransputerTransputer
  22. macro def handleError(f: (Throwable) => Unit): ForeverSelectorBuilder
    Definition Classes
    ForeverSelectorBuilder
  23. def handleErrorWithFlowTerminationAsync(f: (ExecutionContext, FlowTermination[Unit], Continuated[Unit], Throwable) => Future[Unit]): SelectorRunner.this.type
    Definition Classes
    ForeverSelectorBuilder
    Annotations
    @inline()
  24. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  25. macro def idle(body: Unit): ForeverSelectorBuilder
    Definition Classes
    ForeverSelectorBuilder
  26. macro def input[B](f: PartialFunction[Any, B]): Input[B]
    Definition Classes
    ForeverSelectorBuilder
  27. def inputBuilder[B](): InputSelectorBuilder[B]
    Definition Classes
    ForeverSelectorBuilder
  28. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  29. implicit def logSource: LogSource[Transputer]
    Definition Classes
    Transputer
  30. macro def loop(f: PartialFunction[Any, Unit]): Unit

    configure loop in selector

    configure loop in selector

    Definition Classes
    SelectTransputer
  31. macro def map[B](f: (Any) => B): Input[B]

    provide syntax for creating output channels.

    provide syntax for creating output channels.

    val multiplexed = for(s <- gopherApi.select.forever) yield
         s match {
            case x: channelA => s"A:${x}"
            case x: channelB => s"B:${x}"
         }
    Definition Classes
    ForeverSelectorBuilder
  32. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  33. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  34. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  35. def onError(arg: ErrorSelectorArgument[Unit]): SelectorRunner.this.type
    Definition Classes
    SelectorBuilder
  36. def onEscalatedFailure(ex: Throwable): Unit

    called when failure is escalated.

    called when failure is escalated.

    Attributes
    protected
    Definition Classes
    SelectTransputerTransputer
  37. def onIdle(arg: SkipSelectorArgument[Unit]): SelectorRunner.this.type
    Definition Classes
    SelectorBuilder
  38. def onRead[E](ch: Input[E])(arg: ReadSelectorArgument[E, Unit]): SelectorRunner.this.type
    Definition Classes
    SelectorBuilder
  39. def onRestart(prev: Transputer): Unit

    called when transducer is restarted.

    called when transducer is restarted.

    prev

    - previous (i.e. failed) instance of trnasputer.

    Attributes
    protected
    Definition Classes
    Transputer
  40. def onResume(): Unit

    called when transducer is choose to resume durign recovery.

    called when transducer is choose to resume durign recovery.

    Attributes
    protected
    Definition Classes
    Transputer
  41. def onStart(): Unit

    called when transducer is started.

    called when transducer is started.

    Attributes
    protected
    Definition Classes
    Transputer
  42. def onStop(): Unit

    called when transputer is stopped.

    called when transputer is stopped.

    Attributes
    protected
    Definition Classes
    SelectTransputerTransputer
  43. def onTimeout(t: FiniteDuration)(arg: SkipSelectorArgument[Unit]): SelectorRunner.this.type
    Definition Classes
    SelectorBuilder
  44. def onWrite[E](ch: Output[E])(arg: WriteSelectorArgument[E, Unit]): SelectorRunner.this.type
    Definition Classes
    SelectorBuilder
  45. macro def reading[A](ch: Input[A])(f: (A) => Unit): ForeverSelectorBuilder
    Definition Classes
    ForeverSelectorBuilder
  46. def readingWithFlowTerminationAsync[A](ch: Input[A], f: (ExecutionContext, FlowTermination[Unit], A) => Future[Unit]): SelectorRunner.this.type
    Definition Classes
    ForeverSelectorBuilder
  47. def recover(f: PartialFunction[Throwable, Directive]): SelectorRunner.this.type

    set recover function

    set recover function

    Definition Classes
    Transputer
  48. def recoverAppend(f: PartialFunction[Throwable, Directive]): SelectorRunner.this.type

    append recover function to existing

    append recover function to existing

    Definition Classes
    Transputer
  49. def recoverFactory: () => (ReplicatedTransputer.this)#SelectorRunner

    Used for recover failed instances

    Used for recover failed instances

    Definition Classes
    SelectorRunnerTransputer
  50. def replica: Int

    return replica number of current instance, if transponder run replicated.

    return replica number of current instance, if transponder run replicated.

    Attributes
    protected
    Definition Classes
    Transputer
  51. val selectorInit: () => Unit
    Attributes
    protected
    Definition Classes
    SelectTransputer
  52. def selectorRun: Future[Unit]
    Definition Classes
    SelectorBuilder
  53. def start(): Future[Unit]
    Definition Classes
    Transputer
  54. def stop(): Unit
    Definition Classes
    SelectTransputerTransputer
  55. final def synchronized[T0](arg0: => T0): T0
    Definition Classes
    AnyRef
  56. macro def timeout(t: FiniteDuration)(f: (FiniteDuration) => Unit): ForeverSelectorBuilder
    Definition Classes
    ForeverSelectorBuilder
  57. def timeoutWithFlowTerminationAsync(t: FiniteDuration, f: (ExecutionContext, FlowTermination[Unit], FiniteDuration) => Future[Unit]): SelectorRunner.this.type
    Definition Classes
    ForeverSelectorBuilder
    Annotations
    @inline()
  58. def toString(): String
    Definition Classes
    AnyRef → Any
  59. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  60. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException]) @native()
  61. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  62. def withError(f: (ExecutionContext, FlowTermination[Unit], Continuated[Unit], Throwable) => Future[Continuated[Unit]]): SelectorRunner.this.type
    Definition Classes
    SelectorBuilder
    Annotations
    @inline()
  63. def withIdle(f: (Skip[Unit]) => Option[Future[Continuated[Unit]]]): SelectorRunner.this.type
    Definition Classes
    SelectorBuilder
    Annotations
    @inline()
  64. def withReader[B](ch: Input[B], f: (ContRead[B, Unit]) => Option[(In[B]) => Future[Continuated[Unit]]]): SelectorRunner.this.type
    Definition Classes
    SelectorBuilder
    Annotations
    @inline()
  65. def withTimeout(t: FiniteDuration)(f: (Skip[Unit]) => Option[Future[Continuated[Unit]]]): SelectorRunner.this.type
    Definition Classes
    SelectorBuilder
    Annotations
    @inline()
  66. def withWriter[B](ch: Output[B], f: (ContWrite[B, Unit]) => Option[(B, Future[Continuated[Unit]])]): SelectorRunner.this.type
    Definition Classes
    SelectorBuilder
    Annotations
    @inline()
  67. macro def writing[A](ch: Output[A], x: A)(f: (A) => Unit): ForeverSelectorBuilder
    Definition Classes
    ForeverSelectorBuilder
  68. def writingWithFlowTerminationAsync[A](ch: Output[A], x: => A, f: (ExecutionContext, FlowTermination[Unit], A) => Future[Unit]): ForeverSelectorBuilder
    Definition Classes
    ForeverSelectorBuilder
    Annotations
    @inline()

Deprecated Value Members

  1. def finalize(): Unit
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.Throwable]) @Deprecated
    Deprecated

Inherited from SelectTransputer

Inherited from Transputer

Inherited from ForeverSelectorBuilder

Inherited from SelectorBuilder[Unit]

Inherited from AnyRef

Inherited from Any

Ungrouped