/** * @module misc * This module contains miscellaneous functions that don't fit in another category - [see the documentation for more info](https://github.com/Sv443-Network/UserUtils/blob/main/docs.md#misc) */ import type { ListLike, Prettify, Stringifiable } from "./types.ts"; /** * A ValueGen value is either its type, a promise that resolves to its type, or a function that returns its type, either synchronous or asynchronous. * ValueGen allows for the utmost flexibility when applied to any type, as long as {@linkcode consumeGen()} is used to get the final value. * The optional `TFn` parameter allows specifying the function variant's signature, enabling parametrized consumption via {@linkcode consumeGen()}. * @template TValueType The type of the value that the ValueGen should yield * @template TFn The function signature for the function variant - defaults to a no-arg function for backwards compatibility */ export type ValueGen TValueType | Promise = () => TValueType | Promise> = TValueType | Promise | TFn; /** * Turns a {@linkcode ValueGen} into its final value. * @param args Optional arguments forwarded to the function, if the ValueGen is a parametrized function * @template TValueType The type of the value that the ValueGen should yield * @template TFn The function signature for the function variant - inferred automatically */ export declare function consumeGen TValueType | Promise = () => TValueType | Promise>(valGen: ValueGen, ...args: Parameters): Promise; /** * A StringGen value is either a string, anything that can be converted to a string, or a function that returns one of the previous two, either synchronous or asynchronous, or a promise that returns a string. * StringGen allows for the utmost flexibility when dealing with strings, as long as {@linkcode consumeStringGen()} is used to get the final string. * The optional `TFn` parameter allows specifying the function variant's signature, enabling parametrized consumption via {@linkcode consumeStringGen()}. * @template TFn The function signature for the function variant - defaults to a no-arg function for backwards compatibility */ export type StringGen Stringifiable | Promise = () => Stringifiable | Promise> = ValueGen; /** * Turns a {@linkcode StringGen} into its final string value. * @param args Optional arguments forwarded to the function, if the StringGen is a parametrized function * @template TStrUnion The union of strings that the StringGen should yield - this allows for finer type control compared to {@linkcode consumeGen()} * @template TFn The function signature for the function variant - inferred automatically */ export declare function consumeStringGen Stringifiable | Promise = () => Stringifiable | Promise>(strGen: StringGen, ...args: Parameters): Promise; /** Options for the `fetchAdvanced()` function */ export type FetchAdvancedOpts = Prettify & RequestInit>; /** Calls the fetch API with special options like a timeout */ export declare function fetchAdvanced(input: string | RequestInfo | URL, options?: FetchAdvancedOpts): Promise; /** * Returns the length of the given list-like object (anything with a numeric `length`, `size` or `count` property, like an array, Map or NodeList). * If the object doesn't have any of these properties, it will return 0 by default. * Set {@linkcode zeroOnInvalid} to false to return NaN instead of 0 if the object doesn't have any of the properties. */ export declare function getListLength(listLike: ListLike, zeroOnInvalid?: boolean): number; /** * Pauses async execution for the specified time in ms. * If an `AbortSignal` is passed, the pause will be aborted when the signal is triggered. * By default, this will resolve the promise, but you can set {@linkcode rejectOnAbort} to true to reject it instead. */ export declare function pauseFor(time: number, signal?: AbortSignal, rejectOnAbort?: boolean): Promise; /** * Turns the passed object into a "pure" object without a prototype chain, meaning it won't have any default properties like `toString`, `__proto__`, `__defineGetter__`, etc. * This makes the object immune to prototype pollution attacks and allows for cleaner object literals, at the cost of being harder to work with in some cases. * It also effectively transforms a `Stringifiable` value into one that will throw a TypeError when stringified instead of defaulting to `[object Object]` * If no object is passed, it will return an empty object without prototype chain. */ export declare function pureObj(obj?: TObj): TObj; /** * Transforms an object's enumerable, own, string-keyed properties into getters that return the original values. * Set `asCopy` to true to return a new object with the getterified properties instead of a live view of the original object. */ export declare function getterifyObj(obj: TObj, asCopy?: boolean): TObj; /** * Works similarly to `setInterval()`, but the callback is also called immediately and can be aborted with an `AbortSignal`. * Uses `setInterval()` internally, which might cause overlapping calls if the callback's synchronous execution takes longer than the given interval time. * This function will prevent skewing the interval time, contrary to {@linkcode setImmediateTimeoutLoop()}. * Returns a cleanup function that will stop the interval if called. */ export declare function setImmediateInterval(callback: () => void | unknown, interval: number, signal?: AbortSignal): void; /** * Works similarly to `setInterval()`, but the callback is also called immediately and can be aborted with an `AbortSignal`. * Uses `setTimeout()` internally to avoid overlapping calls, though this will skew the given interval time by however long the callback takes to execute synchronously. * Returns a cleanup function that will stop the interval if called. */ export declare function setImmediateTimeoutLoop(callback: () => void | unknown | Promise, interval: number, signal?: AbortSignal): void; /** * Schedules an exit of the current process after the next event loop tick, in order to allow any pending operations like IO writes to complete. * Works on both Node.js and Deno, but will not work in browser environments. * @param code The exit code to use, defaults to 0 (success) * @param timeout The time in milliseconds to wait before exiting, defaults to 0 (exit on the next event loop tick) * @throws An error if no exit method is available (e.g. in browser environments) */ export declare function scheduleExit(code?: number, timeout?: number): void; /** * Returns the current call stack, starting at the caller of this function. * @param asArray Whether to return the stack as an array of strings or a single string. Defaults to true. * @param lines The number of lines to return from the stack. Defaults to Infinity (all of them). */ export declare function getCallStack(asArray?: TAsArray, lines?: number): TAsArray extends true ? string[] : string; /** Options object for {@linkcode createRecurringTask()} */ export type RecurringTaskOptions = { /** Timeout between running the task, in milliseconds. For async tasks and conditions, the timeout will be added onto the execution time of the Promises. */ timeout: number; /** * The task to run. Can return a value or a Promise that resolves to a value of any type, which will be passed to the optional callback once the task is finished. * Gets passed the current iteration (starting at 0) as an argument. If no `condition` is given, the task will run indefinitely, or until aborted via the `signal`, `abortOnError` or `maxIterations` options. */ task: (iteration: number) => TVal | Promise; /** * Condition that needs to return true in order to run the task. If not given, the task will run indefinitely with the given timeout. * Gets passed the current iteration (starting at 0) as an argument. A failing condition will still increment the iterations. */ condition?: (iteration: number) => boolean | Promise; /** Gets called with the task's return value and iteration number every time it's finished. Can be an async function if asynchronous operations are needed in the callback. */ onSuccess?: (value: TVal, iteration: number) => void | Promise; /** Gets called with the error if the `task`, `condition` or `onSuccess` functions throw an error or return a rejected Promise. Can be an async function if asynchronous operations are needed in the callback. */ onError?: (error: unknown, iteration: number) => void | Promise; /** * If true, the recurring task will stop if the condition or task functions throw an error or return a rejected Promise. Defaults to false. * - ⚠️ If neither `onError` nor `abortOnError` are set, errors will be re-thrown, which could potentially crash the process if not handled by the caller. */ abortOnError?: boolean; /** Max number of times to run the task. If not given, will run indefinitely as long as the condition is true. */ maxIterations?: number; /** Optional AbortSignal to cancel the task. */ signal?: AbortSignal; /** Whether to run the task immediately on the first call or wait for the first timeout to pass. Defaults to true. */ immediate?: boolean; }; /** * Schedules a task to run immediately and repeatedly at the given timeout as long as the given condition returns true. * Ensures no overlapping task executions and multiple ways to cleanly stop the repeated execution. * @returns A promise that resolves once the task is stopped, either by the condition returning false, reaching the max iterations, or the signal being aborted. */ export declare function createRecurringTask(options: RecurringTaskOptions): Promise;