@typed/fp
Version:
Data Structures and Resources for fp-ts
259 lines (232 loc) • 8.1 kB
text/typescript
/**
* FromEnv is a Typeclass which represents the Natural Transformation from an Env into another
* effect.
*
* @since 0.9.2
*/
import { Chain, Chain2, Chain3, Chain4, chainFirst } from 'fp-ts/Chain'
import { flow } from 'fp-ts/function'
import { HKT, HKT2, Kind2, Kind3, Kind4, URIS2, URIS3, URIS4 } from 'fp-ts/HKT'
import {
NaturalTransformation22,
NaturalTransformation23R,
NaturalTransformation23RC,
NaturalTransformation24R,
} from 'fp-ts/NaturalTransformation'
import * as E from './Env'
import { ApplyVariance, Hkt, Initial } from './HKT'
import * as Provide from './Provide'
/**
* @since 0.9.2
* @category Typeclass
*/
export type FromEnv<F> = {
readonly URI?: F
readonly fromEnv: <E, A>(env: E.Env<E, A>) => HKT2<F, E, A>
}
/**
* @since 0.9.2
* @category Combinator
*/
export type FromEnv2<F extends URIS2> = {
readonly URI?: F
readonly fromEnv: NaturalTransformation22<E.URI, F>
}
/**
* @since 0.9.2
* @category Typeclass
*/
export type FromEnv3<F extends URIS3> = {
readonly URI?: F
readonly fromEnv: NaturalTransformation23R<E.URI, F>
}
/**
* @since 0.9.2
* @category Typeclass
*/
export type FromEnv3C<F extends URIS3, E> = {
readonly URI?: F
readonly fromEnv: NaturalTransformation23RC<E.URI, F, E>
}
/**
* @since 0.9.2
* @category Typeclass
*/
export type FromEnv4<F extends URIS4> = {
readonly URI?: F
readonly fromEnv: NaturalTransformation24R<E.URI, F>
}
/**
* @since 0.9.2
* @category Constructor
*/
export function fromEnvK<F extends URIS2>(
F: FromEnv2<F>,
): <A extends readonly any[], R, B>(
f: (...args: A) => E.Env<R, B>,
) => (...args: A) => Hkt<F, [R, B]>
export function fromEnvK<F extends URIS3>(
F: FromEnv3<F>,
): <A extends readonly any[], R, B>(
f: (...args: A) => E.Env<R, B>,
) => <E>(...args: A) => Hkt<F, [R, E, B]>
export function fromEnvK<F extends URIS4>(
F: FromEnv4<F>,
): <A extends readonly any[], R, B>(
f: (...args: A) => E.Env<R, B>,
) => <S, E>(...args: A) => Hkt<F, [S, R, E, B]>
export function fromEnvK<F>(
F: FromEnv<F>,
): <A extends readonly any[], E, B>(
f: (...args: A) => E.Env<E, B>,
) => (...args: A) => Hkt<F, [E, B]>
export function fromEnvK<F>(F: FromEnv<F>) {
return <A extends readonly any[], E, B>(f: (...args: A) => E.Env<E, B>) =>
(...args: A) =>
F.fromEnv(f(...args))
}
/**
* @since 0.9.2
* @category Combinator
*/
export function chainEnvK<F extends URIS2>(
F: FromEnv2<F>,
C: Chain2<F>,
): <A, R1, B>(
f: (value: A) => E.Env<R1, B>,
) => <R2>(hkt: Hkt<F, [R2, A]>) => Hkt<F, [ApplyVariance<F, 'E', [R1, R2]>, B]>
export function chainEnvK<F extends URIS3>(
F: FromEnv3<F>,
C: Chain3<F>,
): <A, R1, B>(
f: (value: A) => E.Env<R1, B>,
) => <R2, E>(hkt: Hkt<F, [R2, E, A]>) => Hkt<F, [ApplyVariance<F, 'R', [R1, R2]>, E, B]>
export function chainEnvK<F extends URIS4>(
F: FromEnv4<F>,
C: Chain4<F>,
): <A, R1, B>(
f: (value: A) => E.Env<R1, B>,
) => <S, R2, E>(hkt: Hkt<F, [S, R2, E, A]>) => Hkt<F, [S, ApplyVariance<F, 'R', [R1, R2]>, E, B]>
export function chainEnvK<F>(
F: FromEnv<F>,
C: Chain<F>,
): <A, R1, B>(
f: (value: A) => E.Env<R1, B>,
) => <R2>(hkt: Hkt<F, [R2, A]>) => Hkt<F, [ApplyVariance<F, 'E', [R1, R2]>, B]>
export function chainEnvK<F>(
F: FromEnv<F>,
C: Chain<F>,
): <A, R, B>(f: (value: A) => E.Env<R, B>) => (hkt: HKT<F, A>) => HKT<F, B> {
return (f) => C.chain(flow(f, F.fromEnv) as any)
}
/**
* @since 0.9.2
* @category Combinator
*/
export function chainFirstEnvK<F extends URIS2>(
F: FromEnv2<F>,
C: Chain2<F>,
): <A, R1, B>(
f: (value: A) => E.Env<R1, B>,
) => <R2>(hkt: Hkt<F, [R2, A]>) => Hkt<F, [ApplyVariance<F, 'E', [R1, R2]>, A]>
export function chainFirstEnvK<F extends URIS3>(
F: FromEnv3<F>,
C: Chain3<F>,
): <A, R1, B>(
f: (value: A) => E.Env<R1, B>,
) => <R2, E>(hkt: Hkt<F, [R2, E, A]>) => Hkt<F, [ApplyVariance<F, 'R', [R1, R2]>, E, A]>
export function chainFirstEnvK<F extends URIS4>(
F: FromEnv4<F>,
C: Chain4<F>,
): <A, R1, B>(
f: (value: A) => E.Env<R1, B>,
) => <S, R2, E>(hkt: Hkt<F, [S, R2, E, A]>) => Hkt<F, [S, ApplyVariance<F, 'R', [R1, R2]>, E, A]>
export function chainFirstEnvK<F>(
F: FromEnv<F>,
C: Chain<F>,
): <A, R1, B>(
f: (value: A) => E.Env<R1, B>,
) => <R2>(hkt: Hkt<F, [R2, A]>) => Hkt<F, [ApplyVariance<F, 'E', [R1, R2]>, A]>
export function chainFirstEnvK<F>(
F: FromEnv<F>,
C: Chain<F>,
): <A, E, B>(f: (value: A) => E.Env<E, B>) => (hkt: HKT<F, A>) => HKT<F, A> {
const chainF = chainFirst(C)
return (f) => chainF(flow(f, F.fromEnv) as any)
}
/**
* @since 0.9.2
* @category Combinator
*/
export function provideSomeWithEnv<F extends URIS4>(
F: FromEnv4<F> & Provide.ProvideSome4<F> & Chain4<F>,
): <E, A>(env: E.Env<E, A>) => Provide.Provider4<F, A, E, Initial<F, 'S'>, Initial<F, 'E'>>
export function provideSomeWithEnv<F extends URIS3>(
F: FromEnv3<F> & Provide.ProvideSome3<F> & Chain3<F>,
): <E, A>(env: E.Env<E, A>) => Provide.Provider3<F, A, E, Initial<F, 'E'>>
export function provideSomeWithEnv<F extends URIS2>(
F: FromEnv2<F> & Provide.ProvideSome2<F> & Chain2<F>,
): <E, A>(env: E.Env<E, A>) => Provide.Provider2<F, A, E>
export function provideSomeWithEnv<F>(
F: FromEnv<F> & Provide.ProvideSome<F> & Chain<F>,
): <E, A>(env: E.Env<E, A>) => Provide.Provider<F, A, E>
export function provideSomeWithEnv<F>(F: FromEnv<F> & Provide.ProvideSome<F> & Chain<F>) {
return flow(F.fromEnv, Provide.provideSomeWith(F))
}
/**
* @since 0.9.2
* @category Combinator
*/
export function provideAllWithEnv<F extends URIS4>(
F: FromEnv4<F> & Provide.ProvideAll4<F> & Chain4<F>,
): <R, A>(env: E.Env<R, A>) => <S, E, B>(hkt: Kind4<F, S, A, E, B>) => Kind4<F, S, R, E, B>
export function provideAllWithEnv<F extends URIS3>(
F: FromEnv3<F> & Provide.ProvideAll3<F> & Chain3<F>,
): <R, A>(env: E.Env<R, A>) => <E, B>(hkt: Kind3<F, A, E, B>) => Kind3<F, R, E, B>
export function provideAllWithEnv<F extends URIS2>(
F: FromEnv2<F> & Provide.ProvideAll2<F> & Chain2<F>,
): <E, A>(env: E.Env<E, A>) => <B>(hkt: Kind2<F, A, B>) => Kind2<F, E, B>
export function provideAllWithEnv<F>(
F: FromEnv<F> & Provide.ProvideAll<F> & Chain<F>,
): <E, A>(env: E.Env<E, A>) => <B>(hkt: HKT2<F, A, B>) => HKT2<F, E, B>
export function provideAllWithEnv<F>(F: FromEnv<F> & Provide.ProvideAll<F> & Chain<F>) {
return flow(F.fromEnv, Provide.provideAllWith(F))
}
/**
* @since 0.9.2
* @category Combinator
*/
export function useSomeWithEnv<F extends URIS4>(
F: FromEnv4<F> & Provide.UseSome4<F> & Chain4<F>,
): <E, A>(env: E.Env<E, A>) => Provide.Provider4<F, A, E, Initial<F, 'S'>, Initial<F, 'E'>>
export function useSomeWithEnv<F extends URIS3>(
F: FromEnv3<F> & Provide.UseSome3<F> & Chain3<F>,
): <E, A>(env: E.Env<E, A>) => Provide.Provider3<F, A, E, Initial<F, 'E'>>
export function useSomeWithEnv<F extends URIS2>(
F: FromEnv2<F> & Provide.UseSome2<F> & Chain2<F>,
): <E, A>(env: E.Env<E, A>) => Provide.Provider2<F, A, E>
export function useSomeWithEnv<F>(
F: FromEnv<F> & Provide.UseSome<F> & Chain<F>,
): <E, A>(env: E.Env<E, A>) => Provide.Provider<F, A, E>
export function useSomeWithEnv<F>(F: FromEnv<F> & Provide.UseSome<F> & Chain<F>) {
return flow(F.fromEnv, Provide.useSomeWith(F))
}
/**
* @since 0.9.2
* @category Combinator
*/
export function useAllWithEnv<F extends URIS4>(
F: FromEnv4<F> & Provide.UseAll4<F> & Chain4<F>,
): <R, A>(env: E.Env<R, A>) => <S, E, B>(hkt: Kind4<F, S, A, E, B>) => Kind4<F, S, R, E, B>
export function useAllWithEnv<F extends URIS3>(
F: FromEnv3<F> & Provide.UseAll3<F> & Chain3<F>,
): <R, A>(env: E.Env<R, A>) => <E, B>(hkt: Kind3<F, A, E, B>) => Kind3<F, R, E, B>
export function useAllWithEnv<F extends URIS2>(
F: FromEnv2<F> & Provide.UseAll2<F> & Chain2<F>,
): <E, A>(env: E.Env<E, A>) => <B>(hkt: Kind2<F, A, B>) => Kind2<F, E, B>
export function useAllWithEnv<F>(
F: FromEnv<F> & Provide.UseAll<F> & Chain<F>,
): <E, A>(env: E.Env<E, A>) => <B>(hkt: HKT2<F, A, B>) => HKT2<F, E, B>
export function useAllWithEnv<F>(F: FromEnv<F> & Provide.UseAll<F> & Chain<F>) {
return flow(F.fromEnv, Provide.useAllWith(F))
}