/** * The `Const` type constructor, which wraps its first type argument and ignores its second. * That is, `Const` is isomorphic to `E` for any `A`. * * `Const` has some useful instances. For example, the `Applicative` instance allows us to collect results using a `Monoid` * while ignoring return values. * * @since 2.0.0 */ import { Applicative2C } from './Applicative' import { Apply2C } from './Apply' import { Bifunctor2 } from './Bifunctor' import { BooleanAlgebra } from './BooleanAlgebra' import { Bounded } from './Bounded' import { Contravariant2 } from './Contravariant' import { Eq } from './Eq' import { Functor2 } from './Functor' import { HeytingAlgebra } from './HeytingAlgebra' import { Monoid } from './Monoid' import { Ord } from './Ord' import { Ring } from './Ring' import { Semigroup } from './Semigroup' import { Semiring } from './Semiring' import { Show } from './Show' /** * @category model * @since 2.0.0 */ export declare type Const = E & { readonly _A: A } /** * @category constructors * @since 2.0.0 */ export declare const make: (e: E) => Const /** * @category instances * @since 2.0.0 */ export declare function getShow(S: Show): Show> /** * @category instances * @since 2.0.0 */ export declare const getEq: (E: Eq) => Eq> /** * @category instances * @since 2.6.0 */ export declare const getOrd: (O: Ord) => Ord> /** * @category instances * @since 2.6.0 */ export declare const getBounded: (B: Bounded) => Bounded> /** * @category instances * @since 2.6.0 */ export declare const getSemigroup: (S: Semigroup) => Semigroup> /** * @category instances * @since 2.6.0 */ export declare const getMonoid: (M: Monoid) => Monoid> /** * @category instances * @since 2.6.0 */ export declare const getSemiring: (S: Semiring) => Semiring> /** * @category instances * @since 2.6.0 */ export declare const getRing: (S: Ring) => Ring> /** * @category instances * @since 2.6.0 */ export declare const getHeytingAlgebra: (H: HeytingAlgebra) => HeytingAlgebra> /** * @category instances * @since 2.6.0 */ export declare const getBooleanAlgebra: (H: BooleanAlgebra) => BooleanAlgebra> /** * @category instances * @since 2.0.0 */ export declare function getApply(S: Semigroup): Apply2C /** * @category instances * @since 2.0.0 */ export declare function getApplicative(M: Monoid): Applicative2C /** * @since 2.0.0 */ export declare const contramap: (f: (b: B) => A) => (fa: Const) => Const /** * `map` can be used to turn functions `(a: A) => B` into functions `(fa: F) => F` whose argument and return types * use the type constructor `F` to represent some computational context. * * @category mapping * @since 2.0.0 */ export declare const map: (f: (a: A) => B) => (fa: Const) => Const /** * Map a pair of functions over the two type arguments of the bifunctor. * * @category mapping * @since 2.6.2 */ export declare const bimap: (f: (e: E) => G, g: (a: A) => B) => (fa: Const) => Const /** * Map a function over the first type argument of a bifunctor. * * @category error handling * @since 2.6.2 */ export declare const mapLeft: (f: (e: E) => G) => (fa: Const) => Const /** * @category type lambdas * @since 2.0.0 */ export declare const URI = 'Const' /** * @category type lambdas * @since 2.0.0 */ export declare type URI = typeof URI declare module './HKT' { interface URItoKind2 { readonly [URI]: Const } } /** * @category instances * @since 2.7.0 */ export declare const Functor: Functor2 /** * @category mapping * @since 2.10.0 */ export declare const flap: (a: A) => (fab: Const B>) => Const /** * @category instances * @since 2.7.0 */ export declare const Contravariant: Contravariant2 /** * @category instances * @since 2.7.0 */ export declare const Bifunctor: Bifunctor2 /** * This instance is deprecated, use small, specific instances instead. * For example if a function needs a `Functor` instance, pass `C.Functor` instead of `C.const_` * (where `C` is from `import C from 'fp-ts/Const'`) * * @category zone of death * @since 2.0.0 * @deprecated */ export declare const const_: Functor2 & Contravariant2 & Bifunctor2