对 B 序列进行一次硬核遍历。请注意,我在这里使用了 List ,因为 Scalaz 7 似乎没有 typeclass 实例Seq
,但是如果真的需要,编写自己的实例应该不会太难。
import scalaz.{ValidationNEL, Traverse, NonEmptyList}
import scalaz.std.list.listInstance
case class A(a: Int)
case class B(b: Int)
case class C(c: Int)
def foo( a: A ): ValidationNEL[String,List[B]] = Validation.success(List(B(1), B(2)))
def bar( b: B ): ValidationNEL[String,C] = Validation.failure(NonEmptyList("error in " + b.b))//Validation.success(C(b.b * 2))
type ValNEL[A] = ValidationNEL[String, A]
def foobar(a: A): ValidationNEL[String, List[C]] =
foo(a) flatMap { bs =>
Traverse[List].traverse[ValNEL, B, C](bs)(bar)
}
val r: scalaz.ValidationNEL[String, List[C]] = foobar(A(3))
更新:另请参阅宝贵的Haskellwiki Typeclassopedia