All Downloads are FREE. Search and download functionalities are using the official Maven repository.

scalaprops.scalazlaws.cobind.scala Maven / Gradle / Ivy

package scalaprops
package scalazlaws

import scalaprops.Property.forAll
import scalaz._
import scalaz.std.anyVal._

object cobind {

  def cobindAssociative[F[_], A, B, C, D](implicit F: Cobind[F], D: Equal[D], fa: Gen[F[A]],
                                            f: Gen[F[A] => B], g: Gen[F[B] => C], h: Gen[F[C] => D]): Property =
    forAll(F.cobindLaw.cobindAssociative[A, B, C, D] _)

  def laws[F[_]](implicit a: Cobind[F], am: Gen[F[Int]], e: Equal[F[Int]], g: Gen[F[Int] => Int]): Properties[ScalazLaw] =
    Properties.fromChecks(ScalazLaw.cobind)(
      ScalazLaw.cobindAssociative -> Check(
        cobindAssociative[F, Int, Int, Int, Int], Param.maxSize(10)
      )
    )

  def all[F[_]](implicit a: Cobind[F], am: Gen[F[Int]], e: Equal[F[Int]], g: Gen[F[Int] => Int]): Properties[ScalazLaw] =
    Properties.fromProps(ScalazLaw.cobindAll, cobind.laws[F], functor.all[F])
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy