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

    channels.SelectFactory

    channels.SelectorBuilder

    channels.Output

    channels.Input

    channels.Channel

    GopherAPI

  • package goasync
    Definition Classes
    gopher
  • AsyncApply
  • AsyncIterable
  • AsyncOption
  • AsyncWrapper
  • GoAsync
o

gopher.goasync

GoAsync

object GoAsync

async arround go.

Basicly go is

  1. translate await-like exressions inside inline functions to calls of appropriative async functions. (or show error if not found). x.foreach{ x => p; await(x); .. } become await( transform-defer( x.foreachAsync{ x => async(p; await(x); ..) }) ) (note, that channel.read macroses are expanded to await-s on this point)

2. transform defer calls if defer statement is found inside go: asnyc{ p .. defer(x) .. } become (reallity is a little complext, here is just idea) { val d = new Defers(); async{ p .. d.defer(x) .. }.onComplete(d.tryProcess) }

Linear Supertypes
AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. GoAsync
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. def applyAsync[T](c: Context)(nbody: scala.reflect.macros.blackbox.Context.Tree)(ec: scala.reflect.macros.blackbox.Context.Expr[ExecutionContext])(implicit arg0: scala.reflect.macros.blackbox.Context.WeakTypeTag[T]): scala.reflect.macros.blackbox.Context.Tree
  5. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  6. def clone(): AnyRef
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  7. def containsDefer[T](c: Context)(body: scala.reflect.macros.blackbox.Context.Expr[T])(implicit arg0: scala.reflect.macros.blackbox.Context.WeakTypeTag[T]): Boolean
  8. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  9. def equals(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  10. def finalize(): Unit
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  11. def findAwait(c: Context)(body: scala.reflect.macros.blackbox.Context.Tree): Boolean
  12. final def getClass(): Class[_]
    Definition Classes
    AnyRef → Any
  13. def goImpl[T](c: Context)(body: scala.reflect.macros.blackbox.Context.Expr[T])(ec: scala.reflect.macros.blackbox.Context.Expr[ExecutionContext])(implicit arg0: scala.reflect.macros.blackbox.Context.WeakTypeTag[T]): scala.reflect.macros.blackbox.Context.Expr[Future[T]]
  14. def goScopeImpl[T](c: Context)(body: scala.reflect.macros.blackbox.Context.Expr[T])(implicit arg0: scala.reflect.macros.blackbox.Context.WeakTypeTag[T]): scala.reflect.macros.blackbox.Context.Expr[T]
  15. def hashCode(): Int
    Definition Classes
    AnyRef → Any
  16. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  17. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  18. final def notify(): Unit
    Definition Classes
    AnyRef
  19. final def notifyAll(): Unit
    Definition Classes
    AnyRef
  20. final def synchronized[T0](arg0: ⇒ T0): T0
    Definition Classes
    AnyRef
  21. def toString(): String
    Definition Classes
    AnyRef → Any
  22. def transformAsyncBody[T](c: Context)(body: scala.reflect.macros.blackbox.Context.Tree)(implicit arg0: scala.reflect.macros.blackbox.Context.WeakTypeTag[T]): scala.reflect.macros.blackbox.Context.Tree
  23. def transformDefer[T](c: Context)(body: scala.reflect.macros.blackbox.Context.Tree)(implicit arg0: scala.reflect.macros.blackbox.Context.WeakTypeTag[T]): scala.reflect.macros.blackbox.Context.Tree
  24. macro def transformDeferMacro[T](body: Future[T]): Future[T]
  25. def transformDeferMacroImpl[T](c: Context)(body: scala.reflect.macros.blackbox.Context.Expr[Future[T]])(implicit arg0: scala.reflect.macros.blackbox.Context.WeakTypeTag[T]): scala.reflect.macros.blackbox.Context.Expr[Future[T]]
  26. def transformInlineHofCall1(c: Context)(fun: scala.reflect.macros.blackbox.Context.Tree, param: scala.reflect.macros.blackbox.Context.Tree, body: scala.reflect.macros.blackbox.Context.Tree, implicitParams: List[scala.reflect.macros.blackbox.Context.Tree]): scala.reflect.macros.blackbox.Context.Tree
  27. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  28. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  29. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from AnyRef

Inherited from Any

Ungrouped