UNPKG

@typed/fp

Version:

Data Structures and Resources for fp-ts

667 lines (578 loc) 20.6 kB
/** * @typed/fp/FxT is a transformer for creating Do-notation compatible versions of * other data types. * * @since 0.13.0 */ import { Apply, Apply1, Apply2, Apply3, Apply4 } from 'fp-ts/Apply' import { Either, left, match, right } from 'fp-ts/Either' import { FromReader, FromReader2, FromReader3, FromReader3C, FromReader4 } from 'fp-ts/FromReader' import { flow, identity, pipe } from 'fp-ts/function' import { HKT, HKT2, Kind, Kind2, Kind3, Kind4, URIS, URIS2, URIS3, URIS4 } from 'fp-ts/HKT' import { NaturalTransformation, NaturalTransformation11, NaturalTransformation12, NaturalTransformation12C, NaturalTransformation13, NaturalTransformation13C, NaturalTransformation14, NaturalTransformation14C, NaturalTransformation21, NaturalTransformation22, NaturalTransformation22C, NaturalTransformation23, NaturalTransformation23C, NaturalTransformation23R, NaturalTransformation24, NaturalTransformation24R, NaturalTransformation24S, NaturalTransformation33, NaturalTransformation34, } from 'fp-ts/NaturalTransformation' import { Pointed, Pointed1, Pointed2, Pointed3, Pointed4 } from 'fp-ts/Pointed' import { A, U } from 'ts-toolbelt' import { Arity1 } from './function' import { chain as chain_, doFx, Fx, map as map_ } from './Fx' import { ApplyVariance, Hkt, Initial } from './HKT' import { MonadRec, MonadRec1, MonadRec2, MonadRec2C, MonadRec3, MonadRec4 } from './MonadRec' import { ProvideAll, ProvideAll2, ProvideAll3, ProvideAll4, ProvideSome, ProvideSome2, ProvideSome3, ProvideSome4, UseAll, UseAll2, UseAll3, UseAll4, UseSome, UseSome2, UseSome3, UseSome4, } from './Provide' /** * @category Model * @since 0.13.0 */ export type FxT<F, Params extends readonly any[]> = Params extends readonly [...infer Init, infer R] ? Fx<Hkt<F, readonly [...Init, unknown]>, R> : never /** * @category Type-level * @since 0.13.0 */ export type LiftFx<F> = F extends URIS ? LiftFx1<F> : F extends URIS2 ? LiftFx2<F> : F extends URIS3 ? LiftFx3<F> : F extends URIS4 ? LiftFx4<F> : LiftFxHKT<F> /** * @category Type-level * @since 0.13.0 */ export type LiftFx1<F extends URIS> = <A>(kind: Kind<F, A>) => Fx<Kind<F, A>, A> /** * @category Type-level * @since 0.13.0 */ export type LiftFx2<F extends URIS2> = <E, A>( kind: Kind2<F, OrUnknown<E>, A>, ) => Fx<Kind2<F, OrUnknown<E>, A>, A> type IsNever<T> = A.Equals<[T], [never]> extends 1 ? true : false type OrUnknown<T> = IsNever<T> extends true ? unknown : T /** * @category Type-level * @since 0.13.0 */ export type LiftFx3<F extends URIS3> = <R, E, A>( kind: Kind3<F, OrUnknown<R>, E, A>, ) => Fx<Kind3<F, OrUnknown<R>, E, A>, A> /** * @category Type-level * @since 0.13.0 */ export type LiftFx4<F extends URIS4> = <S, R, E, A>( kind: Kind4<F, S, OrUnknown<R>, E, A>, ) => Fx<Kind4<F, S, OrUnknown<R>, E, A>, A> /** * @category Type-level * @since 0.13.0 */ export type LiftFxHKT<F> = <A>(kind: HKT<F, A>) => Fx<HKT<F, A>, A> /** * Create a lift function that will convert any F<A> into Fx<F<A>, A> * @category Constructor * @since 0.13.0 */ export const liftFx = <F>() => lift_ as LiftFx<F> function lift_<F, A>(hkt: HKT<F, A>): Fx<typeof hkt, A> { return { [Symbol.iterator]: function* () { const value: unknown = yield hkt return value as A }, } } /** * @category Lift * @since 0.13.0 */ export function getDo<F extends URIS>(): <Y extends Kind<F, any>, R, N = unknown>( f: (lift: LiftFx1<F>) => Generator<Y, R, N>, ) => Fx<Y, R, N> export function getDo<F extends URIS2, E = any>(): <Y extends Kind2<F, E, any>, R, N = unknown>( f: (lift: LiftFx2<F>) => Generator<Y, R, N>, ) => Fx<Y, R, N> export function getDo<F extends URIS3, R = any, E = any>(): < Y extends Kind3<F, R, E, any>, Z, N = unknown, >( f: (lift: LiftFx3<F>) => Generator<Y, Z, N>, ) => Fx<Y, Z, N> export function getDo<F extends URIS4, S = any, R = any, E = any>(): < Y extends Kind4<F, S, R, E, any>, Z, N = unknown, >( f: (lift: LiftFx4<F>) => Generator<Y, Z, N>, ) => Fx<Y, Z, N> export function getDo<F>(): <Y extends HKT<F, any>, R, N = unknown>( f: (lift: LiftFxHKT<F>) => Generator<Y, R, N>, ) => Fx<Y, R, N> export function getDo<F>() { const lift = liftFx<F>() return <Y extends Hkt<F, readonly [...any[], R]>, R, N = unknown>( f: (lift: LiftFxHKT<F>) => Generator<Y, R, N>, ): Fx<Y, R, N> => doFx(() => f(lift as LiftFxHKT<F>)) } type Kind2E<F extends URIS2, E> = [E] extends [Kind2<F, infer R, any>] ? R : never type Kind3E<F extends URIS3, E> = [E] extends [Kind3<F, any, infer R, any>] ? R : never type Kind3R<F extends URIS3, E> = [E] extends [Kind3<F, infer R, any, any>] ? R : never type Kind4E<F extends URIS4, E> = [E] extends [Kind4<F, any, any, infer R, any>] ? R : never type Kind4R<F extends URIS4, E> = [E] extends [Kind4<F, any, infer R, any, any>] ? R : never type Kind4S<F extends URIS4, E> = [E] extends [Kind4<F, infer R, any, any, any>] ? R : never /** * @category Interpreter * @since 0.13.0 */ export function toMonad<F extends URIS>( M: MonadRec1<F>, ): <E extends Kind<F, any>, R>(fx: Fx<E, R>) => Kind<F, R> export function toMonad<F extends URIS2>( M: MonadRec2<F>, ): <E extends Kind2<F, any, any>, R>( fx: Fx<E, R>, ) => Kind2<F, ApplyVariance<F, 'E', U.ListOf<Kind2E<F, E>>>, R> export function toMonad<F extends URIS2, S>( M: MonadRec2C<F, S>, ): <E extends Kind2<F, S, any>, R>(fx: Fx<E, R>) => Kind2<F, S, R> export function toMonad<F extends URIS3>( M: MonadRec3<F>, ): <E extends Kind3<F, any, any, any>, R>( fx: Fx<E, R>, ) => Kind3< F, ApplyVariance<F, 'R', U.ListOf<Kind3R<F, E>>>, ApplyVariance<F, 'E', U.ListOf<Kind3E<F, E>>>, R > export function toMonad<F extends URIS4>( M: MonadRec4<F>, ): <E extends Kind4<F, any, any, any, any>, R>( fx: Fx<E, R>, ) => Kind4< F, ApplyVariance<F, 'S', U.ListOf<Kind4S<F, E>>>, ApplyVariance<F, 'R', U.ListOf<Kind4R<F, E>>>, ApplyVariance<F, 'E', U.ListOf<Kind4E<F, E>>>, R > export function toMonad<F>(M: MonadRec<F>): <E, R>(fx: Fx<E, R>) => HKT<F, R> /** * Using a ChainRec instance we can create a stack-safe interpreter for do-notation * using Fx + generators. */ export function toMonad<F>(M: MonadRec<F>) { return function fxToMonad<E extends HKT<F, any>, R>(fx: Fx<E, R>): HKT<F, R> { return pipe( M.of(fx[Symbol.iterator]), M.map((f) => f()), M.chain((generator) => { const result = generator.next() if (result.done) { return M.of(result.value) } return pipe( result.value, M.chain( M.chainRec((a) => { const result = generator.next(a) return result.done ? pipe(result.value, right, M.of) : pipe(result.value, M.map(left)) }), ), ) }), ) } } /** * @category Combinator * @since 0.13.0 */ export function map<F extends URIS>(): <A, B>( f: (value: A) => B, ) => (fx: FxT<F, [A]>) => FxT<F, [B]> export function map<F extends URIS2>(): <A, B>( f: (value: A) => B, ) => <E>(fx: FxT<F, [E, A]>) => FxT<F, [E, B]> export function map<F extends URIS3>(): <A, B>( f: (value: A) => B, ) => <R, E>(fx: FxT<F, [R, E, A]>) => FxT<F, [R, E, B]> export function map<F extends URIS4>(): <A, B>( f: (value: A) => B, ) => <S, R, E>(fx: FxT<F, [S, R, E, A]>) => FxT<F, [S, R, E, B]> export function map<F>(): <A, B>(f: (value: A) => B) => (fx: FxT<F, [A]>) => FxT<F, [B]> export function map() { return map_ } /** * @category Combinator * @since 0.13.0 */ export function chain<F extends URIS>(): <A, B>( f: (value: A) => FxT<F, [B]>, ) => (fx: FxT<F, [A]>) => FxT<F, [ApplyVariance<F, 'A', [B, A]>]> export function chain<F extends URIS2>(): <A, E1, B>( f: (value: A) => FxT<F, [E1, B]>, ) => <E2>(fx: FxT<F, [E2, A]>) => FxT<F, [ApplyVariance<F, 'E', [E1, E2]>, B]> export function chain<F extends URIS3>(): <A, R1, E1, B>( f: (value: A) => FxT<F, [R1, E1, B]>, ) => <R2, E2>( fx: FxT<F, [R2, E2, A]>, ) => FxT< F, [ApplyVariance<F, 'R', [R1, R2]>, ApplyVariance<F, 'E', [E1, E2]>, ApplyVariance<F, 'A', [B, A]>] > export function chain<F extends URIS4>(): <A, S1, R1, E1, B>( f: (value: A) => FxT<F, [S1, R1, E1, B]>, ) => <S2, R2, E2>( fx: FxT<F, [S2, R2, E2, A]>, ) => FxT< F, [ ApplyVariance<F, 'S', [S1, S2]>, ApplyVariance<F, 'R', [R1, R2]>, ApplyVariance<F, 'E', [E1, E2]>, ApplyVariance<F, 'A', [B, A]>, ] > export function chain<F>(): <A, B>(f: (value: A) => FxT<F, [B]>) => (fx: FxT<F, [A]>) => FxT<F, [B]> export function chain() { return chain_ } /** * @category Combinator * @since 0.13.0 */ export function ap<F extends URIS>( M: MonadRec1<F> & Apply1<F>, ): <A>(fa: FxT<F, [A]>) => <B>(fab: FxT<F, [Arity1<A, B>]>) => FxT<F, [B]> export function ap<F extends URIS2>( M: MonadRec2<F> & Apply2<F>, ): <E1, A>( fa: FxT<F, [E1, A]>, ) => <E2, B>(fab: FxT<F, [E2, Arity1<A, B>]>) => FxT<F, [ApplyVariance<F, 'E', [E1, E2]>, B]> export function ap<F extends URIS2, E>( M: MonadRec2<F> & Apply2<F>, ): <A>(fa: FxT<F, [E, A]>) => <B>(fab: FxT<F, [E, Arity1<A, B>]>) => FxT<F, [E, B]> export function ap<F extends URIS3>( M: MonadRec3<F> & Apply3<F>, ): <R1, E1, A>( fa: FxT<F, [R1, E1, A]>, ) => <R2, E2, B>( fab: FxT<F, [R2, E2, Arity1<A, B>]>, ) => FxT<F, [ApplyVariance<F, 'R', [R1, R2]>, ApplyVariance<F, 'E', [E1, E2]>, B]> export function ap<F extends URIS4>( M: MonadRec4<F> & Apply4<F>, ): <S1, R1, E1, A>( fa: FxT<F, [S1, R1, E1, A]>, ) => <S2, R2, E2, B>( fab: FxT<F, [S2, R2, E2, Arity1<A, B>]>, ) => FxT< F, [ ApplyVariance<F, 'S', [S1, S2]>, ApplyVariance<F, 'R', [R1, R2]>, ApplyVariance<F, 'E', [E1, E2]>, B, ] > export function ap<F>( M: MonadRec<F> & Apply<F>, ): <A>(fa: FxT<F, [A]>) => <B>(fab: FxT<F, [Arity1<A, B>]>) => FxT<F, [B]> export function ap<F>(M: MonadRec<F> & Apply<F>) { const lift = liftFx() const to = toMonad(M) return <A>(fa: FxT<F, [A]>) => <B>(fab: FxT<F, [Arity1<A, B>]>): FxT<F, [B]> => pipe(fab, to, pipe(fa, to, M.ap), lift) as FxT<F, [B]> } /** * @category Combinator * @since 0.13.0 */ export function chainRec<F extends URIS>(M: MonadRec1<F>): ChainRecFxT<F> export function chainRec<F extends URIS2>(M: MonadRec2<F>): ChainRecFxT<F> export function chainRec<F extends URIS3>(M: MonadRec3<F>): ChainRecFxT<F> export function chainRec<F extends URIS4>(M: MonadRec4<F>): ChainRecFxT<F> export function chainRec<F>(M: MonadRec<F>): ChainRecFxT<F> { return chainRec_(M) as ChainRecFxT<F> } /** * @category Type-level * @since 0.13.0 */ export type ChainRecFxT<F> = F extends URIS2 ? <A, E, B>(f: Arity1<A, FxT<F, [E, Either<A, B>]>>) => (a: A) => FxT<F, [E, B]> : F extends URIS3 ? <A, R, E, B>(f: Arity1<A, FxT<F, [R, E, Either<A, B>]>>) => (a: A) => FxT<F, [R, E, B]> : F extends URIS4 ? <A, S, R, E, B>(f: Arity1<A, FxT<F, [S, R, E, Either<A, B>]>>) => (a: A) => FxT<F, [S, R, E, B]> : <A, B>(f: Arity1<A, FxT<F, [Either<A, B>]>>) => (a: A) => FxT<F, [B]> function chainRec_<F>(M: MonadRec<F>) { const to = toMonad(M) const lift = liftFx() return <A, B>(f: Arity1<A, FxT<F, [Either<A, B>]>>) => (a: A): FxT<F, [B]> => { const fbm = pipe( f(a), to, M.chain( match( M.chainRec((a) => pipe(a, f, to)), M.of, ), ), ) return lift(fbm) as FxT<F, [B]> } } /** * @category Constructor * @since 0.13.0 */ export function of<F extends URIS>(M: Pointed1<F>): <A>(value: A) => Fx<Hkt<F, [A]>, A> export function of<F extends URIS2>( M: Pointed2<F>, ): <A, E = Initial<F, 'E'>>(value: A) => Fx<Hkt<F, [E, A]>, A> export function of<F extends URIS3>( M: Pointed3<F>, ): <A, R = Initial<F, 'R'>, E = Initial<F, 'E'>>(value: A) => Fx<Hkt<F, [R, E, A]>, A> export function of<F extends URIS4>( M: Pointed4<F>, ): <A, S = Initial<F, 'S'>, R = Initial<F, 'R'>, E = Initial<F, 'E'>>( value: A, ) => Fx<Hkt<F, [S, R, E, A]>, A> export function of<F>(M: Pointed<F>): <A>(value: A) => Fx<HKT<F, A>, A> export function of<F>(M: Pointed<F>) { const lift = liftFx() return <A>(value: A) => lift(M.of(value)) } /** * @category Constructor * @since 0.13.0 */ export function ask<F extends URIS2>(M: FromReader2<F>): <A>() => Fx<Hkt<F, [A, A]>, A> export function ask<F extends URIS3>( M: FromReader3<F>, ): <A>() => Fx<Hkt<F, [A, Initial<F, 'E'>, A]>, A> export function ask<F extends URIS3, E>(M: FromReader3C<F, E>): <A>() => Fx<Hkt<F, [A, E, A]>, A> export function ask<F extends URIS4>( M: FromReader4<F>, ): <A>() => Fx<Hkt<F, [Initial<F, 'S'>, A, Initial<F, 'E'>, A]>, A> export function ask<F>(M: FromReader<F>): <A>() => Fx<HKT2<F, A, A>, A> export function ask<F>(M: FromReader<F>) { const lift = liftFx() return () => lift(M.fromReader(identity)) } /** * @category Combinator * @since 0.13.0 */ export function useSome<F extends URIS2>( M: UseSome2<F> & MonadRec2<F>, ): <A>(provided: A) => <B, T>(fx: Fx<Hkt<F, [A & B, unknown]>, T>) => Fx<Hkt<F, [B, unknown]>, T> export function useSome<F extends URIS3>( M: UseSome3<F> & MonadRec3<F>, ): <A>( provided: A, ) => <B, E, T>(fx: Fx<Hkt<F, [A & B, E, unknown]>, T>) => Fx<Hkt<F, [B, E, unknown]>, T> export function useSome<F extends URIS4>( M: UseSome4<F> & MonadRec4<F>, ): <A>( provided: A, ) => <B, S, E, T>(fx: Fx<Hkt<F, [S, A & B, E, unknown]>, T>) => Fx<Hkt<F, [S, B, E, unknown]>, T> export function useSome<F>( M: UseSome<F> & MonadRec<F>, ): <A>(provided: A) => <B, T>(fx: Fx<HKT2<F, A & B, unknown>, T>) => Fx<HKT2<F, B, unknown>, T> export function useSome<F>(M: UseSome<F> & MonadRec<F>) { const lift = liftFx() const to = toMonad(M) return <A>(provided: A) => <B, R>(fx: Fx<HKT2<F, A & B, unknown>, R>) => pipe(fx, to, (x) => M.useSome(provided)(x as any), lift) } /** * @category Combinator * @since 0.13.0 */ export function provideSome<F extends URIS2>( M: ProvideSome2<F> & MonadRec2<F>, ): <A>(provided: A) => <B, T>(fx: Fx<Hkt<F, [A & B, unknown]>, T>) => Fx<Hkt<F, [B, unknown]>, T> export function provideSome<F extends URIS3>( M: ProvideSome3<F> & MonadRec3<F>, ): <A>( provided: A, ) => <B, E, T>(fx: Fx<Hkt<F, [A & B, E, unknown]>, T>) => Fx<Hkt<F, [B, E, unknown]>, T> export function provideSome<F extends URIS4>( M: ProvideSome4<F> & MonadRec4<F>, ): <A>( provided: A, ) => <B, S, E, T>(fx: Fx<Hkt<F, [S, A & B, E, unknown]>, T>) => Fx<Hkt<F, [S, B, E, unknown]>, T> export function provideSome<F>( M: ProvideSome<F> & MonadRec<F>, ): <A>(provided: A) => <B, T>(fx: Fx<HKT2<F, A & B, unknown>, T>) => Fx<HKT2<F, B, unknown>, T> export function provideSome<F>(M: ProvideSome<F> & MonadRec<F>) { const lift = liftFx() const to = toMonad(M) return <A>(provided: A) => <B, R>(fx: Fx<HKT2<F, A & B, unknown>, R>) => pipe(fx, to, (x) => M.provideSome(provided)(x as any), lift) } /** * @category Combinator * @since 0.13.0 */ export function useAll<F extends URIS2>( M: UseAll2<F> & MonadRec2<F>, ): <A>(provided: A) => <T>(fx: Fx<Hkt<F, [A, unknown]>, T>) => Fx<Hkt<F, [unknown, unknown]>, T> export function useAll<F extends URIS3>( M: UseAll3<F> & MonadRec3<F>, ): <A>( provided: A, ) => <E, T>(fx: Fx<Hkt<F, [A, E, unknown]>, T>) => Fx<Hkt<F, [unknown, E, unknown]>, T> export function useAll<F extends URIS4>( M: UseAll4<F> & MonadRec4<F>, ): <A>( provided: A, ) => <S, E, T>(fx: Fx<Hkt<F, [S, A, E, unknown]>, T>) => Fx<Hkt<F, [S, unknown, E, unknown]>, T> export function useAll<F>( M: UseAll<F> & MonadRec<F>, ): <A>(provided: A) => <T>(fx: Fx<HKT2<F, A, unknown>, T>) => Fx<HKT2<F, unknown, unknown>, T> export function useAll<F>(M: UseAll<F> & MonadRec<F>) { const lift = liftFx() const to = toMonad(M) return <A>(provided: A) => <R>(fx: Fx<HKT2<F, A, unknown>, R>) => pipe(fx, to, (x) => M.useAll(provided)(x as any), lift) } /** * @category Combinator * @since 0.13.0 */ export function provideAll<F extends URIS2>( M: ProvideAll2<F> & MonadRec2<F>, ): <A>(provided: A) => <T>(fx: Fx<Hkt<F, [A, unknown]>, T>) => Fx<Hkt<F, [unknown, unknown]>, T> export function provideAll<F extends URIS3>( M: ProvideAll3<F> & MonadRec3<F>, ): <A>( provided: A, ) => <E, T>(fx: Fx<Hkt<F, [A, E, unknown]>, T>) => Fx<Hkt<F, [unknown, E, unknown]>, T> export function provideAll<F extends URIS4>( M: ProvideAll4<F> & MonadRec4<F>, ): <A>( provided: A, ) => <S, E, T>(fx: Fx<Hkt<F, [S, A, E, unknown]>, T>) => Fx<Hkt<F, [S, unknown, E, unknown]>, T> export function provideAll<F>( M: ProvideAll<F> & MonadRec<F>, ): <A>(provided: A) => <T>(fx: Fx<HKT2<F, A, unknown>, T>) => Fx<HKT2<F, unknown, unknown>, T> export function provideAll<F>(M: ProvideAll<F> & MonadRec<F>) { const lift = liftFx() const to = toMonad(M) return <A>(provided: A) => <R>(fx: Fx<HKT2<F, A, unknown>, R>) => pipe(fx, to, (x) => M.provideAll(provided)(x as any), lift) } /** * @category Natural Transformation * @since 0.13.0 */ export function fromNaturalTransformation<F extends URIS, G extends URIS>( transformation: NaturalTransformation11<F, G>, ): <A>(fa: Kind<F, A>) => Fx<Kind<G, A>, A> export function fromNaturalTransformation<F extends URIS, G extends URIS2>( transformation: NaturalTransformation12<F, G>, ): <A, E = Initial<G, 'E'>>(fa: Kind<F, A>) => Fx<Kind2<G, E, A>, A> export function fromNaturalTransformation<F extends URIS, G extends URIS2, E>( transformation: NaturalTransformation12C<F, G, E>, ): <A>(fa: Kind<F, A>) => Fx<Kind2<G, E, A>, A> export function fromNaturalTransformation<F extends URIS, G extends URIS3>( transformation: NaturalTransformation13<F, G>, ): <A, R = Initial<G, 'R'>, E = Initial<G, 'E'>>(fa: Kind<F, A>) => Fx<Kind3<G, R, E, A>, A> export function fromNaturalTransformation<F extends URIS, G extends URIS3, E>( transformation: NaturalTransformation13C<F, G, E>, ): <A, R = Initial<G, 'R'>>(fa: Kind<F, A>) => Fx<Kind3<G, R, E, A>, A> export function fromNaturalTransformation<F extends URIS, G extends URIS4>( transformation: NaturalTransformation14<F, G>, ): <A, S = Initial<G, 'S'>, R = Initial<G, 'R'>, E = Initial<G, 'E'>>( fa: Kind<F, A>, ) => Fx<Kind4<G, S, R, E, A>, A> export function fromNaturalTransformation<F extends URIS, G extends URIS4, E>( transformation: NaturalTransformation14C<F, G, E>, ): <A, S = Initial<G, 'S'>, R = Initial<G, 'R'>>(fa: Kind<F, A>) => Fx<Kind4<G, S, R, E, A>, A> export function fromNaturalTransformation<F extends URIS2, G extends URIS>( transformation: NaturalTransformation21<F, G>, ): <E, A>(fa: Kind2<F, E, A>) => Fx<Kind<G, A>, A> export function fromNaturalTransformation<F extends URIS2, G extends URIS2>( transformation: NaturalTransformation22<F, G>, ): <E, A>(fa: Kind2<F, E, A>) => Fx<Kind2<G, E, A>, A> export function fromNaturalTransformation<F extends URIS2, G extends URIS2, E>( transformation: NaturalTransformation22C<F, G, E>, ): <A>(fa: Kind2<F, E, A>) => Fx<Kind2<G, E, A>, A> export function fromNaturalTransformation<F extends URIS2, G extends URIS3>( transformation: NaturalTransformation23<F, G> | NaturalTransformation23R<F, G>, ): <E, A, R = Initial<G, 'R'>>(fa: Kind2<F, E, A>) => Fx<Kind3<G, R, E, A>, A> export function fromNaturalTransformation<F extends URIS2, G extends URIS3, E>( transformation: NaturalTransformation23C<F, G, E>, ): <A, R = Initial<G, 'R'>>(fa: Kind2<F, E, A>) => Fx<Kind3<G, R, E, A>, A> export function fromNaturalTransformation<F extends URIS2, G extends URIS4>( transformation: | NaturalTransformation24<F, G> | NaturalTransformation24R<F, G> | NaturalTransformation24S<F, G>, ): <E, A, S = Initial<G, 'S'>, R = Initial<G, 'R'>>( fa: Kind2<F, E, A>, ) => Fx<Kind4<G, S, R, E, A>, A> export function fromNaturalTransformation<F extends URIS3, G extends URIS3>( transformation: NaturalTransformation33<F, G>, ): <R, E, A>(fa: Kind3<F, R, E, A>) => Fx<Kind3<G, R, E, A>, A> export function fromNaturalTransformation<F extends URIS3, G extends URIS4>( transformation: NaturalTransformation34<F, G>, ): <R, E, A, S = Initial<G, 'S'>>(fa: Kind3<F, R, E, A>) => Fx<Kind4<G, S, R, E, A>, A> export function fromNaturalTransformation<F, G>( transformation: NaturalTransformation<F, G>, ): <A>(fa: HKT<F, A>) => Fx<HKT<G, A>, A> export function fromNaturalTransformation<F, G>( transformation: NaturalTransformation<F, G>, ): <A>(fa: HKT<F, A>) => Fx<HKT<G, A>, A> { return flow(transformation, liftFx()) as any }