Options
All
  • Public
  • Public/Protected
  • All
Menu

Type class laws defined for CoflatMap.

This is an abstract definition. In order to use it in unit testing, the implementor must think of a strategy to evaluate the truthiness of the returned Equiv values.

Even though in TypeScript the Funfix library is using classes to express these laws, when implementing this class it is recommended that you implement it as a mixin using implements, instead of extending it directly with extends. See TypeScript: Mixins for details and note that we already have applyMixins defined.

We are doing this in order to support multiple inheritance and to avoid inheriting any static members. In the Flow definitions (e.g. .js.flow files) for Funfix these classes are defined with interface, as they are meant to be interfaces that sometimes have default implementations and not classes.

Type parameters

  • F

Hierarchy

  • CoflatMapLaws

Implements

Implemented by

Index

Properties

F

F: CoflatMap<F>

The CoflatMap designated instance for F, to be tested.

covariantComposition

covariantComposition: function

Type declaration

    • <A, B, C>(fa: HK<F, A>, f: function, g: function): Equiv<HK<F, C>>
    • Type parameters

      • A

      • B

      • C

      Parameters

      • fa: HK<F, A>
      • f: function
          • (a: A): B
          • Parameters

            • a: A

            Returns B

      • g: function
          • (b: B): C
          • Parameters

            • b: B

            Returns C

      Returns Equiv<HK<F, C>>

covariantIdentity

covariantIdentity: function

Type declaration

    • Type parameters

      • A

      Parameters

      • fa: HK<F, A>

      Returns Equiv<HK<F, A>>

Methods

coflatMapAssociativity

  • coflatMapAssociativity<A, B, C>(fa: HK<F, A>, f: function, g: function): Equiv<HK<F, C>>
  •  fa.coflatMap(f).coflatMap(g) <-> fa.coflatMap(x => g(x.coflatMap(f)))
    

    Type parameters

    • A

    • B

    • C

    Parameters

    • fa: HK<F, A>
    • f: function
        • (a: HK<F, A>): B
        • Parameters

          • a: HK<F, A>

          Returns B

    • g: function
        • (b: HK<F, B>): C
        • Parameters

          • b: HK<F, B>

          Returns C

    Returns Equiv<HK<F, C>>

coflatMapIdentity

  • coflatMapIdentity<A>(fa: HK<F, A>): Equiv<HK<F, HK<F, A>>>
  • fa.coflatten <-> fa.coflatMap(identity)
    

    Type parameters

    • A

    Parameters

    • fa: HK<F, A>

    Returns Equiv<HK<F, HK<F, A>>>

coflattenCoherence

  • coflattenCoherence<A, B>(fa: HK<F, A>, f: function): Equiv<HK<F, B>>
  • fa.coflatMap(f) <-> fa.coflatten.map(f)
    

    Type parameters

    • A

    • B

    Parameters

    • fa: HK<F, A>
    • f: function
        • (a: HK<F, A>): B
        • Parameters

          • a: HK<F, A>

          Returns B

    Returns Equiv<HK<F, B>>

coflattenThroughMap

  • coflattenThroughMap<A>(fa: HK<F, A>): Equiv<HK<F, HK<F, HK<F, A>>>>
  • fa.coflatten.coflatten <-> fa.coflatten.map(_.coflatten)
    

    Type parameters

    • A

    Parameters

    • fa: HK<F, A>

    Returns Equiv<HK<F, HK<F, HK<F, A>>>>

Legend

  • Module
  • Object literal
  • Variable
  • Function
  • Function with type parameter
  • Index signature
  • Type alias
  • Enumeration
  • Enumeration member
  • Property
  • Method
  • Interface
  • Interface with type parameter
  • Constructor
  • Property
  • Method
  • Index signature
  • Class
  • Class with type parameter
  • Constructor
  • Property
  • Method
  • Accessor
  • Index signature
  • Inherited constructor
  • Inherited property
  • Inherited method
  • Inherited accessor
  • Protected property
  • Protected method
  • Protected accessor
  • Private property
  • Private method
  • Private accessor
  • Static property
  • Static method

Generated using TypeDoc