UNPKG

fp-ts-std

Version:

The missing pseudo-standard library for fp-ts.

75 lines 3.19 kB
/** * Utility functions to accommodate `fp-ts/Monoid`. * * @since 0.12.0 */ import type { Foldable1, Foldable2, Foldable2C, Foldable3, Foldable3C, Foldable4 } from "fp-ts/Foldable"; import type { Kind, Kind2, Kind3, Kind4, URIS, URIS2, URIS3, URIS4 } from "fp-ts/HKT"; import type { Monoid } from "fp-ts/Monoid"; import type { Lazy } from "./Lazy"; /** * Extracts the value from within a foldable, falling back to the monoidal * identity of said value. * * @example * import { toMonoid } from 'fp-ts-std/Monoid' * import * as O from 'fp-ts/Option' * import * as Str from 'fp-ts/string' * * const f = toMonoid(O.Foldable)(Str.Monoid) * * assert.deepStrictEqual(f(O.some('x')), 'x') * assert.deepStrictEqual(f(O.none), '') * * @category 2 Typeclass Methods * @since 0.12.0 */ export declare function toMonoid<F extends URIS4>(F: Foldable4<F>): <A, S, R, E>(G: Monoid<A>) => (x: Kind4<F, S, R, E, A>) => A; export declare function toMonoid<F extends URIS3>(F: Foldable3<F>): <A, R, E>(G: Monoid<A>) => (x: Kind3<F, R, E, A>) => A; export declare function toMonoid<F extends URIS3, E>(F: Foldable3C<F, E>): <A, R>(G: Monoid<A>) => (x: Kind3<F, R, E, A>) => A; export declare function toMonoid<F extends URIS2>(F: Foldable2<F>): <A, E>(G: Monoid<A>) => (x: Kind2<F, E, A>) => A; export declare function toMonoid<F extends URIS2, E>(F: Foldable2C<F, E>): <A>(G: Monoid<A>) => (x: Kind2<F, E, A>) => A; export declare function toMonoid<F extends URIS>(F: Foldable1<F>): <A>(G: Monoid<A>) => (x: Kind<F, A>) => A; /** * Conditionally returns the provided monoidal value or its identity. The dual * to `memptyUnless`. The lazy value is evaluated only if the condition passes. * * @example * import { constant } from 'fp-ts/function' * import { memptyWhen } from 'fp-ts-std/Monoid' * import * as O from 'fp-ts/Option' * import * as Str from 'fp-ts/string' * * const f = memptyWhen(O.getMonoid(Str.Monoid)) * * assert.deepStrictEqual(f(true)(constant(O.some('x'))), O.none) * assert.deepStrictEqual(f(true)(constant(O.none)), O.none) * assert.deepStrictEqual(f(false)(constant(O.some('x'))), O.some('x')) * assert.deepStrictEqual(f(false)(constant(O.none)), O.none) * * @category 2 Typeclass Methods * @since 0.13.0 */ export declare const memptyWhen: <A>(M: Monoid<A>) => (x: boolean) => (y: Lazy<A>) => A; /** * Conditionally returns the provided monoidal value or its identity. The dual * to `memptyWhen`. The lazy value is evaluated only if the condition passes. * * @example * import { constant } from 'fp-ts/function' * import { memptyUnless } from 'fp-ts-std/Monoid' * import * as O from 'fp-ts/Option' * import * as Str from 'fp-ts/string' * * const f = memptyUnless(O.getMonoid(Str.Monoid)) * * assert.deepStrictEqual(f(true)(constant(O.some('x'))), O.some('x')) * assert.deepStrictEqual(f(true)(constant(O.none)), O.none) * assert.deepStrictEqual(f(false)(constant(O.some('x'))), O.none) * assert.deepStrictEqual(f(false)(constant(O.none)), O.none) * * @category 2 Typeclass Methods * @since 0.13.0 */ export declare const memptyUnless: <A>(M: Monoid<A>) => (x: boolean) => (y: Lazy<A>) => A; //# sourceMappingURL=Monoid.d.ts.map