package scalaz package syntax /** Wraps a value `self` and provides methods related to `Arrow` */ trait ArrowOps[F[_, _],A, B] extends Ops[F[A, B]] { implicit def F: Arrow[F] //// final def first[C]: F[(A, C), (B, C)] = F.first(self) final def second[C]: F[(C, A), (C, B)] = F.second(self) final def ***[C, D](k: F[C, D]): F[(A, C), (B, D)] = F.splitA(self, k) final def &&&[C](k: F[A, C]): F[A, (B, C)] = F.combine(self, k) final def product: F[(A, A), (B, B)] = F.product(self) //// } trait ToArrowOps0 { implicit def ToArrowOpsUnapply[FA](v: FA)(implicit F0: Unapply2[Arrow, FA]) = new ArrowOps[F0.M,F0.A,F0.B] { def self = F0(v); implicit def F: Arrow[F0.M] = F0.TC } } trait ToArrowOps extends ToArrowOps0 with ToSplitOps with ToProfunctorOps { implicit def ToArrowOps[F[_, _],A, B](v: F[A, B])(implicit F0: Arrow[F]) = new ArrowOps[F,A, B] { def self = v; implicit def F: Arrow[F] = F0 } //// //// } trait ArrowSyntax[F[_, _]] extends SplitSyntax[F] with ProfunctorSyntax[F] { implicit def ToArrowOps[A, B](v: F[A, B]): ArrowOps[F, A, B] = new ArrowOps[F, A, B] { def self = v; implicit def F: Arrow[F] = ArrowSyntax.this.F } def F: Arrow[F] //// //// }