pekko/akka-actor/src/main/scala/akka/japi/pf/CaseStatements.scala
2014-01-20 12:00:13 +01:00

27 lines
726 B
Scala

/**
* Copyright (C) 2009-2014 Typesafe Inc. <http://www.typesafe.com>
*/
package akka.japi.pf
import FI.{ UnitApply, Apply, Predicate }
private[pf] object CaseStatement {
def empty[F, T](): PartialFunction[F, T] = PartialFunction.empty
}
private[pf] class CaseStatement[F, P, T](predicate: Predicate, apply: Apply[P, T])
extends PartialFunction[F, T] {
override def isDefinedAt(o: F) = predicate.defined(o)
override def apply(o: F) = apply.apply(o.asInstanceOf[P])
}
private[pf] class UnitCaseStatement[F, P](predicate: Predicate, apply: UnitApply[P])
extends PartialFunction[F, Unit] {
override def isDefinedAt(o: F) = predicate.defined(o)
override def apply(o: F) = apply.apply(o.asInstanceOf[P])
}