UNPKG

fp-ts

Version:

Functional programming in TypeScript

187 lines (186 loc) 5.82 kB
/** * A `Functor` is a type constructor which supports a mapping operation `map`. * * `map` can be used to turn functions `a -> b` into functions `f a -> f b` whose argument and return types use the type * constructor `f` to represent some computational context. * * Instances must satisfy the following laws: * * 1. Identity: `F.map(fa, a => a) <-> fa` * 2. Composition: `F.map(fa, a => bc(ab(a))) <-> F.map(F.map(fa, ab), bc)` * * @since 2.0.0 */ import { HKT, Kind, Kind2, Kind3, Kind4, URIS, URIS2, URIS3, URIS4 } from './HKT' /** * @category type classes * @since 2.0.0 */ export interface Functor<F> { readonly URI: F readonly map: <A, B>(fa: HKT<F, A>, f: (a: A) => B) => HKT<F, B> } /** * @category type classes * @since 2.0.0 */ export interface Functor1<F extends URIS> { readonly URI: F readonly map: <A, B>(fa: Kind<F, A>, f: (a: A) => B) => Kind<F, B> } /** * @category type classes * @since 2.0.0 */ export interface Functor2<F extends URIS2> { readonly URI: F readonly map: <E, A, B>(fa: Kind2<F, E, A>, f: (a: A) => B) => Kind2<F, E, B> } /** * @category type classes * @since 2.0.0 */ export interface Functor2C<F extends URIS2, E> { readonly URI: F readonly _E: E readonly map: <A, B>(fa: Kind2<F, E, A>, f: (a: A) => B) => Kind2<F, E, B> } /** * @category type classes * @since 2.0.0 */ export interface Functor3<F extends URIS3> { readonly URI: F readonly map: <R, E, A, B>(fa: Kind3<F, R, E, A>, f: (a: A) => B) => Kind3<F, R, E, B> } /** * @category type classes * @since 2.2.0 */ export interface Functor3C<F extends URIS3, E> { readonly URI: F readonly _E: E readonly map: <R, A, B>(fa: Kind3<F, R, E, A>, f: (a: A) => B) => Kind3<F, R, E, B> } /** * @category type classes * @since 2.0.0 */ export interface Functor4<F extends URIS4> { readonly URI: F readonly map: <S, R, E, A, B>(fa: Kind4<F, S, R, E, A>, f: (a: A) => B) => Kind4<F, S, R, E, B> } /** * @since 2.0.0 */ export interface FunctorComposition<F, G> { readonly map: <A, B>(fa: HKT<F, HKT<G, A>>, f: (a: A) => B) => HKT<F, HKT<G, B>> } /** * @since 2.0.0 */ export interface FunctorCompositionHKT1<F, G extends URIS> { readonly map: <A, B>(fa: HKT<F, Kind<G, A>>, f: (a: A) => B) => HKT<F, Kind<G, B>> } /** * @since 2.0.0 */ export interface FunctorCompositionHKT2<F, G extends URIS2> { readonly map: <E, A, B>(fa: HKT<F, Kind2<G, E, A>>, f: (a: A) => B) => HKT<F, Kind2<G, E, B>> } /** * @since 2.0.0 */ export interface FunctorCompositionHKT2C<F, G extends URIS2, E> { readonly map: <A, B>(fa: HKT<F, Kind2<G, E, A>>, f: (a: A) => B) => HKT<F, Kind2<G, E, B>> } /** * @since 2.0.0 */ export interface FunctorComposition11<F extends URIS, G extends URIS> { readonly map: <A, B>(fa: Kind<F, Kind<G, A>>, f: (a: A) => B) => Kind<F, Kind<G, B>> } /** * @since 2.0.0 */ export interface FunctorComposition12<F extends URIS, G extends URIS2> { readonly map: <E, A, B>(fa: Kind<F, Kind2<G, E, A>>, f: (a: A) => B) => Kind<F, Kind2<G, E, B>> } /** * @since 2.0.0 */ export interface FunctorComposition12C<F extends URIS, G extends URIS2, E> { readonly map: <A, B>(fa: Kind<F, Kind2<G, E, A>>, f: (a: A) => B) => Kind<F, Kind2<G, E, B>> } /** * @since 2.0.0 */ export interface FunctorComposition21<F extends URIS2, G extends URIS> { readonly map: <E, A, B>(fa: Kind2<F, E, Kind<G, A>>, f: (a: A) => B) => Kind2<F, E, Kind<G, B>> } /** * @since 2.0.0 */ export interface FunctorComposition2C1<F extends URIS2, G extends URIS, E> { readonly map: <A, B>(fa: Kind2<F, E, Kind<G, A>>, f: (a: A) => B) => Kind2<F, E, Kind<G, B>> } /** * @since 2.0.0 */ export interface FunctorComposition22<F extends URIS2, G extends URIS2> { readonly map: <FE, GE, A, B>(fa: Kind2<F, FE, Kind2<G, GE, A>>, f: (a: A) => B) => Kind2<F, FE, Kind2<G, GE, B>> } /** * @since 2.0.0 */ export interface FunctorComposition22C<F extends URIS2, G extends URIS2, E> { readonly map: <FE, A, B>(fa: Kind2<F, FE, Kind2<G, E, A>>, f: (a: A) => B) => Kind2<F, FE, Kind2<G, E, B>> } /** * @since 2.2.0 */ export interface FunctorComposition23<F extends URIS2, G extends URIS3> { readonly map: <FE, R, E, A, B>(fa: Kind2<F, FE, Kind3<G, R, E, A>>, f: (a: A) => B) => Kind2<F, FE, Kind3<G, R, E, B>> } /** * @since 2.2.0 */ export interface FunctorComposition23C<F extends URIS2, G extends URIS3, E> { readonly map: <FE, R, A, B>(fa: Kind2<F, FE, Kind3<G, R, E, A>>, f: (a: A) => B) => Kind2<F, FE, Kind3<G, R, E, B>> } /** * @since 2.0.0 */ export declare function getFunctorComposition<F extends URIS2, G extends URIS3, E>( F: Functor2<F>, G: Functor3C<G, E> ): FunctorComposition23C<F, G, E> export declare function getFunctorComposition<F extends URIS2, G extends URIS2, E>( F: Functor2<F>, G: Functor2C<G, E> ): FunctorComposition22C<F, G, E> export declare function getFunctorComposition<F extends URIS2, G extends URIS2>( F: Functor2<F>, G: Functor2<G> ): FunctorComposition22<F, G> export declare function getFunctorComposition<F extends URIS2, G extends URIS, E>( F: Functor2C<F, E>, G: Functor1<G> ): FunctorComposition2C1<F, G, E> export declare function getFunctorComposition<F extends URIS2, G extends URIS>( F: Functor2<F>, G: Functor1<G> ): FunctorComposition21<F, G> export declare function getFunctorComposition<F extends URIS, G extends URIS2, E>( F: Functor1<F>, G: Functor2C<G, E> ): FunctorComposition12C<F, G, E> export declare function getFunctorComposition<F extends URIS, G extends URIS2>( F: Functor1<F>, G: Functor2<G> ): FunctorComposition12<F, G> export declare function getFunctorComposition<F extends URIS, G extends URIS>( F: Functor1<F>, G: Functor1<G> ): FunctorComposition11<F, G> export declare function getFunctorComposition<F, G>(F: Functor<F>, G: Functor<G>): FunctorComposition<F, G>