//#region src/Array/setAt.d.ts /** * # setAt * * ```ts * function Array.setAt( * target: readonly T[], * idx: number, * value: NoInfer, * ): readonly T[] * ``` * * Sets the value at the specified `idx` in `target` to `value`. Returns the original array if the index is out of bounds or the value is already the same. * * ## Example * * ```ts [data-first] * import { Array } from "@monstermann/array"; * * Array.setAt([1, 2, 3], 1, 9); // [1, 9, 3] * Array.setAt([1, 2, 3], -1, 9); // [1, 2, 9] * Array.setAt([1, 2, 3], 5, 9); // [1, 2, 3] * ``` * * ```ts [data-last] * import { Array } from "@monstermann/array"; * * pipe([1, 2, 3], Array.setAt(1, 9)); // [1, 9, 3] * pipe([1, 2, 3], Array.setAt(-1, 9)); // [1, 2, 9] * pipe([1, 2, 3], Array.setAt(5, 9)); // [1, 2, 3] * ``` * */ declare const setAt: { (idx: number, value: NoInfer): (target: T[]) => T[]; (idx: number, value: NoInfer): (target: readonly T[]) => readonly T[]; (target: T[], idx: number, value: NoInfer): T[]; (target: readonly T[], idx: number, value: NoInfer): readonly T[]; }; //#endregion export { setAt };