cats.laws

MonadCombineLaws

trait MonadCombineLaws[F[_]] extends MonadFilterLaws[F] with AlternativeLaws[F]

Laws that must be obeyed by any MonadCombine.

Linear Supertypes
Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. MonadCombineLaws
  2. AlternativeLaws
  3. MonoidKLaws
  4. SemigroupKLaws
  5. MonadFilterLaws
  6. MonadLaws
  7. FlatMapLaws
  8. ApplicativeLaws
  9. ApplyLaws
  10. CartesianLaws
  11. FunctorLaws
  12. InvariantLaws
  13. AnyRef
  14. Any
  1. Hide All
  2. Show all
Learn more about member selection
Visibility
  1. Public
  2. All

Abstract Value Members

  1. implicit abstract def F: MonadCombine[F]

Concrete Value Members

  1. final def !=(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  2. final def !=(arg0: Any): Boolean

    Definition Classes
    Any
  3. final def ##(): Int

    Definition Classes
    AnyRef → Any
  4. final def ==(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  5. final def ==(arg0: Any): Boolean

    Definition Classes
    Any
  6. implicit def algebra[A]: Monoid[F[A]]

    Definition Classes
    AlternativeLaws
  7. def alternativeLeftDistributivity[A, B](fa: F[A], fa2: F[A], f: (A) ⇒ B): IsEq[F[B]]

    Definition Classes
    AlternativeLaws
  8. def alternativeRightAbsorption[A, B](ff: F[(A) ⇒ B]): IsEq[F[B]]

    Definition Classes
    AlternativeLaws
  9. def alternativeRightDistributivity[A, B](fa: F[A], ff: F[(A) ⇒ B], fg: F[(A) ⇒ B]): IsEq[F[B]]

    Definition Classes
    AlternativeLaws
  10. def apProductConsistent[A, B](fa: F[A], f: F[(A) ⇒ B]): IsEq[F[B]]

    Definition Classes
    ApplicativeLaws
  11. def applicativeComposition[A, B, C](fa: F[A], fab: F[(A) ⇒ B], fbc: F[(B) ⇒ C]): IsEq[F[C]]

    This law is applyComposition stated in terms of pure.

    This law is applyComposition stated in terms of pure. It is a combination of applyComposition and applicativeMap and hence not strictly necessary.

    Definition Classes
    ApplicativeLaws
  12. def applicativeHomomorphism[A, B](a: A, f: (A) ⇒ B): IsEq[F[B]]

    Definition Classes
    ApplicativeLaws
  13. def applicativeIdentity[A](fa: F[A]): IsEq[F[A]]

    Definition Classes
    ApplicativeLaws
  14. def applicativeInterchange[A, B](a: A, ff: F[(A) ⇒ B]): IsEq[F[B]]

    Definition Classes
    ApplicativeLaws
  15. def applicativeMap[A, B](fa: F[A], f: (A) ⇒ B): IsEq[F[B]]

    Definition Classes
    ApplicativeLaws
  16. def applyComposition[A, B, C](fa: F[A], fab: F[(A) ⇒ B], fbc: F[(B) ⇒ C]): IsEq[F[C]]

    Definition Classes
    ApplyLaws
  17. final def asInstanceOf[T0]: T0

    Definition Classes
    Any
  18. def cartesianAssociativity[A, B, C](fa: F[A], fb: F[B], fc: F[C]): (F[(A, (B, C))], F[((A, B), C)])

    Definition Classes
    CartesianLaws
  19. def clone(): AnyRef

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  20. def covariantComposition[A, B, C](fa: F[A], f: (A) ⇒ B, g: (B) ⇒ C): IsEq[F[C]]

    Definition Classes
    FunctorLaws
  21. def covariantIdentity[A](fa: F[A]): IsEq[F[A]]

    Definition Classes
    FunctorLaws
  22. final def eq(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  23. def equals(arg0: Any): Boolean

    Definition Classes
    AnyRef → Any
  24. def finalize(): Unit

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  25. def flatMapAssociativity[A, B, C](fa: F[A], f: (A) ⇒ F[B], g: (B) ⇒ F[C]): IsEq[F[C]]

    Definition Classes
    FlatMapLaws
  26. def flatMapConsistentApply[A, B](fa: F[A], fab: F[(A) ⇒ B]): IsEq[F[B]]

    Definition Classes
    FlatMapLaws
  27. final def getClass(): Class[_]

    Definition Classes
    AnyRef → Any
  28. def hashCode(): Int

    Definition Classes
    AnyRef → Any
  29. def invariantComposition[A, B, C](fa: F[A], f1: (A) ⇒ B, f2: (B) ⇒ A, g1: (B) ⇒ C, g2: (C) ⇒ B): IsEq[F[C]]

    Definition Classes
    InvariantLaws
  30. def invariantIdentity[A](fa: F[A]): IsEq[F[A]]

    Definition Classes
    InvariantLaws
  31. final def isInstanceOf[T0]: Boolean

    Definition Classes
    Any
  32. def kleisliAssociativity[A, B, C, D](f: (A) ⇒ F[B], g: (B) ⇒ F[C], h: (C) ⇒ F[D], a: A): IsEq[F[D]]

    The composition of cats.data.Kleisli arrows is associative.

    The composition of cats.data.Kleisli arrows is associative. This is analogous to flatMapAssociativity.

    Definition Classes
    FlatMapLaws
  33. def kleisliLeftIdentity[A, B](a: A, f: (A) ⇒ F[B]): IsEq[F[B]]

    pure is the left identity element under left-to-right composition of cats.data.Kleisli arrows.

    pure is the left identity element under left-to-right composition of cats.data.Kleisli arrows. This is analogous to monadLeftIdentity.

    Definition Classes
    MonadLaws
  34. def kleisliRightIdentity[A, B](a: A, f: (A) ⇒ F[B]): IsEq[F[B]]

    pure is the right identity element under left-to-right composition of cats.data.Kleisli arrows.

    pure is the right identity element under left-to-right composition of cats.data.Kleisli arrows. This is analogous to monadRightIdentity.

    Definition Classes
    MonadLaws
  35. def mapFlatMapCoherence[A, B](fa: F[A], f: (A) ⇒ B): IsEq[F[B]]

    Make sure that map and flatMap are consistent.

    Make sure that map and flatMap are consistent.

    Definition Classes
    MonadLaws
  36. def monadCombineLeftDistributivity[A, B](fa: F[A], fa2: F[A], f: (A) ⇒ F[B]): IsEq[F[B]]

  37. def monadFilterConsistency[A, B](fa: F[A], f: (A) ⇒ Boolean): IsEq[F[A]]

    Definition Classes
    MonadFilterLaws
  38. def monadFilterLeftEmpty[A, B](f: (A) ⇒ F[B]): IsEq[F[B]]

    Definition Classes
    MonadFilterLaws
  39. def monadFilterRightEmpty[A, B](fa: F[A]): IsEq[F[B]]

    Definition Classes
    MonadFilterLaws
  40. def monadLeftIdentity[A, B](a: A, f: (A) ⇒ F[B]): IsEq[F[B]]

    Definition Classes
    MonadLaws
  41. def monadRightIdentity[A](fa: F[A]): IsEq[F[A]]

    Definition Classes
    MonadLaws
  42. def monoidKLeftIdentity[A](a: F[A]): IsEq[F[A]]

    Definition Classes
    MonoidKLaws
  43. def monoidKRightIdentity[A](a: F[A]): IsEq[F[A]]

    Definition Classes
    MonoidKLaws
  44. def monoidalLeftIdentity[A](fa: F[A]): (F[(Unit, A)], F[A])

    Definition Classes
    ApplicativeLaws
  45. def monoidalRightIdentity[A](fa: F[A]): (F[(A, Unit)], F[A])

    Definition Classes
    ApplicativeLaws
  46. final def ne(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  47. final def notify(): Unit

    Definition Classes
    AnyRef
  48. final def notifyAll(): Unit

    Definition Classes
    AnyRef
  49. def semigroupKAssociative[A](a: F[A], b: F[A], c: F[A]): IsEq[F[A]]

    Definition Classes
    SemigroupKLaws
  50. final def synchronized[T0](arg0: ⇒ T0): T0

    Definition Classes
    AnyRef
  51. def toString(): String

    Definition Classes
    AnyRef → Any
  52. final def wait(): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  53. final def wait(arg0: Long, arg1: Int): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  54. final def wait(arg0: Long): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from AlternativeLaws[F]

Inherited from MonoidKLaws[F]

Inherited from SemigroupKLaws[F]

Inherited from MonadFilterLaws[F]

Inherited from MonadLaws[F]

Inherited from FlatMapLaws[F]

Inherited from ApplicativeLaws[F]

Inherited from ApplyLaws[F]

Inherited from CartesianLaws[F]

Inherited from FunctorLaws[F]

Inherited from InvariantLaws[F]

Inherited from AnyRef

Inherited from Any

Ungrouped