class
AsyncHandlerGenerator[C <: Protocol] extends AnyRef
Type Members
-
-
type
I = C.Request
-
type
O = C.Response
-
case class
PackagedRequest(request: I, response: Promise[O]) extends Product with Serializable
Value Members
-
final
def
!=(arg0: AnyRef): Boolean
-
final
def
!=(arg0: Any): Boolean
-
final
def
##(): Int
-
final
def
==(arg0: AnyRef): Boolean
-
final
def
==(arg0: Any): Boolean
-
final
def
asInstanceOf[T0]: T0
-
val
canary: AtomicBoolean
-
val
client: FutureClient[C] { val clientConfig: colossus.service.ClientConfig }
-
def
clone(): AnyRef
-
final
def
eq(arg0: AnyRef): Boolean
-
def
equals(arg0: Any): Boolean
-
def
finalize(): Unit
-
final
def
getClass(): Class[_]
-
def
hashCode(): Int
-
final
def
isInstanceOf[T0]: Boolean
-
final
def
ne(arg0: AnyRef): Boolean
-
final
def
notify(): Unit
-
final
def
notifyAll(): Unit
-
val
proxy: ActorRef
-
final
def
synchronized[T0](arg0: ⇒ T0): T0
-
implicit
val
timeout: Timeout
-
def
toString(): String
-
final
def
wait(): Unit
-
final
def
wait(arg0: Long, arg1: Int): Unit
-
final
def
wait(arg0: Long): Unit
-
val
watchdog: ActorRef
Inherited from AnyRef
Inherited from Any
So we need to take a type-parameterized request object, package it into a monomorphic case class to send to the worker, and have the handler that receives that object able to pattern match out the parameterized object, all without using reflection. We can do that with some nifty path-dependant types