E 'definito nella classe scalaz.Traverse
tipo, dove sembra che questo:
def sequence[G[_]:Applicative,A](fga: F[G[A]]): G[F[A]] =
traversal[G].run[G[A], A](fga)(ga => ga)
scalaz.syntax.TraverseOps
fornisce una versione che viene pimped su List
, dal momento che dispone di un'istanza List
Traverse
.
è possibile importare proprio quello che serve:
import scalaz._, std.list._, std.option._, syntax.traverse._
O tutto e il lavello della cucina:
import scalaz._, Scalaz._
E poi si può usare in questo modo:
scala> val xs: List[Option[Int]] = Some(1) :: Some(2) :: Nil
xs: List[Option[Int]] = List(Some(1), Some(2))
scala> xs.sequence
res0: Option[List[Int]] = Some(List(1, 2))
O se vuoi esattamente la formulazione nella tua domanda:
scala> def sequence[T](l: List[Option[T]]): Option[List[T]] = l.sequence
sequence: [T](l: List[Option[T]])Option[List[T]]
scala> sequence(xs)
res1: Option[List[Int]] = Some(List(1, 2))
fonte
2012-09-04 18:21:23