是否有可能以某种方式将PartialFunction(假设它总是只包含一个案例)编组为人类可读的东西?
假设我们有任何类型的集合(消息:List[Any])和使用模式匹配块定义的 PartialFuntion[Any, T] 的数量。
case object R1
case object R2
case object R3
val pm1: PartialFunction[Any, Any] = {
case "foo" => R1
}
val pm2: PartialFunction[Any, Any] = {
case x: Int if x > 10 => R2
}
val pm3: PartialFunction[Any, Any] = {
case x: Boolean => R3
}
val messages: List[Any] = List("foo", 20)
val functions = List(pm1, pm2)
然后我们可以找到与提供的 PF 和相关应用程序匹配的所有消息
val found: List[Option[Any]] = functions map { f =>
messages.find(f.isDefined).map(f)
}
但是,如果我需要以人类可读的形式(用于日志记录)将“我期望的”结果映射到“我所拥有的”,该怎么办。说,
(case "foo") -> Some(R1)
(case Int if _ > 10) -> Some(R2)
(case Boolean) -> None
那可能吗?一些宏/元作品?