/**
* `Monoid` extends the power of `Semigroup` by providing an additional `empty` value.
*
* ```ts
* interface Semigroup {
* readonly concat: (x: A, y: A) => A
* }
*
* interface Monoid extends Semigroup {
* readonly empty: A
* }
* ```
*
* This `empty` value should be an identity for the `concat` operation, which means the following equalities hold for any choice of `x`.
*
* ```ts
* concat(x, empty) = concat(empty, x) = x
* ```
*
* Many types that form a `Semigroup` also form a `Monoid`, such as `number`s (with `0`) and `string`s (with `''`).
*
* ```ts
* import { Monoid } from 'fp-ts/Monoid'
*
* const monoidString: Monoid = {
* concat: (x, y) => x + y,
* empty: ''
* }
* ```
*
* *Adapted from https://typelevel.org/cats*
*
* @since 2.0.0
*/
import { Bounded } from './Bounded.js';
import { Endomorphism } from './Endomorphism.js';
import { ReadonlyRecord } from './ReadonlyRecord.js';
import * as Se from './Semigroup.js';
/**
* @category model
* @since 2.0.0
*/
export interface Monoid extends Se.Semigroup {
readonly empty: A;
}
/**
* Get a monoid where `concat` will return the minimum, based on the provided bounded order.
*
* The `empty` value is the `top` value.
*
* @example
* import * as N from 'fp-ts/number'
* import * as M from 'fp-ts/Monoid'
*
* const M1 = M.min(N.Bounded)
*
* assert.deepStrictEqual(M1.concat(1, 2), 1)
*
* @category constructors
* @since 2.10.0
*/
export declare const min: (B: Bounded) => Monoid;
/**
* Get a monoid where `concat` will return the maximum, based on the provided bounded order.
*
* The `empty` value is the `bottom` value.
*
* @example
* import * as N from 'fp-ts/number'
* import * as M from 'fp-ts/Monoid'
*
* const M1 = M.max(N.Bounded)
*
* assert.deepStrictEqual(M1.concat(1, 2), 2)
*
* @category constructors
* @since 2.10.0
*/
export declare const max: (B: Bounded) => Monoid;
/**
* The dual of a `Monoid`, obtained by swapping the arguments of `concat`.
*
* @example
* import { reverse } from 'fp-ts/Monoid'
* import * as S from 'fp-ts/string'
*
* assert.deepStrictEqual(reverse(S.Monoid).concat('a', 'b'), 'ba')
*
* @since 2.10.0
*/
export declare const reverse: (M: Monoid) => Monoid;
/**
* Given a struct of monoids returns a monoid for the struct.
*
* @example
* import { struct } from 'fp-ts/Monoid'
* import * as N from 'fp-ts/number'
*
* interface Point {
* readonly x: number
* readonly y: number
* }
*
* const M = struct({
* x: N.MonoidSum,
* y: N.MonoidSum
* })
*
* assert.deepStrictEqual(M.concat({ x: 1, y: 2 }, { x: 3, y: 4 }), { x: 4, y: 6 })
*
* @since 2.10.0
*/
export declare const struct: (monoids: { [K in keyof A]: Monoid; }) => Monoid<{ readonly [K in keyof A]: A[K]; }>;
/**
* Given a tuple of monoids returns a monoid for the tuple.
*
* @example
* import { tuple } from 'fp-ts/Monoid'
* import * as B from 'fp-ts/boolean'
* import * as N from 'fp-ts/number'
* import * as S from 'fp-ts/string'
*
* const M1 = tuple(S.Monoid, N.MonoidSum)
* assert.deepStrictEqual(M1.concat(['a', 1], ['b', 2]), ['ab', 3])
*
* const M2 = tuple(S.Monoid, N.MonoidSum, B.MonoidAll)
* assert.deepStrictEqual(M2.concat(['a', 1, true], ['b', 2, false]), ['ab', 3, false])
*
* @since 2.10.0
*/
export declare const tuple: >(...monoids: { [K in keyof A]: Monoid; }) => Monoid>;
/**
* Given a sequence of `as`, concat them and return the total.
*
* If `as` is empty, return the monoid `empty` value.
*
* @example
* import { concatAll } from 'fp-ts/Monoid'
* import * as N from 'fp-ts/number'
*
* assert.deepStrictEqual(concatAll(N.MonoidSum)([1, 2, 3]), 6)
* assert.deepStrictEqual(concatAll(N.MonoidSum)([]), 0)
*
* @since 2.10.0
*/
export declare const concatAll: (M: Monoid) => ((as: ReadonlyArray) => A);
/**
* Use [`Monoid`](./void.ts.html#monoid) instead.
*
* @category zone of death
* @since 2.0.0
* @deprecated
*/
export declare const monoidVoid: Monoid;
/**
* Use [`tuple`](#tuple) instead.
*
* @category zone of death
* @since 2.0.0
* @deprecated
*/
export declare const getTupleMonoid: >>(...monoids: T) => Monoid<{
[K in keyof T]: T[K] extends Se.Semigroup ? A : never;
}>;
/**
* Use [`struct`](#struct) instead.
*
* @category zone of death
* @since 2.0.0
* @deprecated
*/
export declare const getStructMonoid: >(monoids: {
[K in keyof O]: Monoid;
}) => Monoid;
/**
* Use [`reverse`](#reverse) instead.
*
* @category zone of death
* @since 2.0.0
* @deprecated
*/
export declare const getDualMonoid: (M: Monoid) => Monoid;
/**
* Use [`max`](#max) instead.
*
* @category zone of death
* @since 2.0.0
* @deprecated
*/
export declare const getJoinMonoid: (B: Bounded) => Monoid;
/**
* Use [`min`](#min) instead.
*
* @category zone of death
* @since 2.0.0
* @deprecated
*/
export declare const getMeetMonoid: (B: Bounded) => Monoid;
/**
* Use [`concatAll`](#concatall) instead.
*
* @category zone of death
* @since 2.0.0
* @deprecated
*/
export declare const fold: (M: Monoid) => ((as: ReadonlyArray) => A);
/**
* Use [`MonoidAll`](./boolean.ts.html#monoidall) instead.
*
* @category zone of death
* @since 2.0.0
* @deprecated
*/
export declare const monoidAll: Monoid;
/**
* Use [`MonoidAny`](./boolean.ts.html#monoidany) instead.
*
* @category zone of death
* @since 2.0.0
* @deprecated
*/
export declare const monoidAny: Monoid;
/**
* Use [`getMonoid`](./function.ts.html#getmonoid) instead.
*
* @category zone of death
* @since 2.0.0
* @deprecated
*/
export declare const getFunctionMonoid: (M: Monoid) => () => Monoid<(a: A) => M>;
/**
* Use [`getEndomorphismMonoid`](./function.ts.html#getendomorphismmonoid) instead.
*
* **Note**. The execution order in [`getEndomorphismMonoid`](./function.ts.html#getendomorphismmonoid) is reversed.
*
* @category zone of death
* @since 2.0.0
* @deprecated
*/
export declare const getEndomorphismMonoid: () => Monoid>;
/**
* Use [`Monoid`](./string.ts.html#monoid) instead.
*
* @category zone of death
* @since 2.0.0
* @deprecated
*/
export declare const monoidString: Monoid;
/**
* Use [`MonoidSum`](./number.ts.html#monoidsum) instead.
*
* @category zone of death
* @since 2.0.0
* @deprecated
*/
export declare const monoidSum: Monoid;
/**
* Use [`MonoidProduct`](./number.ts.html#monoidproduct) instead.
*
* @category zone of death
* @since 2.0.0
* @deprecated
*/
export declare const monoidProduct: Monoid;