import { TransferListItem as TransferListItem$1, MessagePort } from 'node:worker_threads'; import { EventEmitterAsyncResource } from 'node:events'; /** Channel for communicating between main thread and workers */ interface TinypoolChannel { /** Workers subscribing to messages */ onMessage(callback: (message: any) => void): void; /** Called with worker's messages */ postMessage(message: any): void; } interface TinypoolWorker { runtime: string; initialize(options: { env?: Record; argv?: string[]; execArgv?: string[]; resourceLimits?: any; workerData: TinypoolData; trackUnmanagedFds?: boolean; }): void; terminate(): Promise; postMessage(message: any, transferListItem?: TransferListItem$1[]): void; setChannel?: (channel: TinypoolChannel) => void; on(event: string, listener: (...args: any[]) => void): void; once(event: string, listener: (...args: any[]) => void): void; emit(event: string, ...data: any[]): void; ref?: () => void; unref?: () => void; threadId: number; } /** * Tinypool's internal messaging between main thread and workers. * - Utilizers can use `__tinypool_worker_message__` property to identify * these messages and ignore them. */ interface TinypoolWorkerMessage { __tinypool_worker_message__: true; source: T; } interface StartupMessage { filename: string | null; name: string; port: MessagePort; sharedBuffer: Int32Array; useAtomics: boolean; } interface RequestMessage { taskId: number; task: any; filename: string; name: string; } interface ReadyMessage { ready: true; } interface ResponseMessage { taskId: number; result: any; error: unknown | null; usedMemory: number; } interface TinypoolPrivateData { workerId: number; } type TinypoolData = [TinypoolPrivateData, any]; declare const kTransferable: unique symbol; declare const kValue: unique symbol; declare const kQueueOptions: unique symbol; declare function isTransferable(value: any): boolean; declare function isMovable(value: any): boolean; declare function markMovable(value: object): void; interface Transferable { readonly [kTransferable]: object; readonly [kValue]: object; } interface Task { readonly [kQueueOptions]: object | null; cancel(): void; } interface TaskQueue { readonly size: number; shift(): Task | null; remove(task: Task): void; push(task: Task): void; cancel(): void; } declare function isTaskQueue(value: any): boolean; declare const kRequestCountField = 0; declare const kResponseCountField = 1; declare const kFieldCount = 2; declare global { namespace NodeJS { interface Process { __tinypool_state__: { isTinypoolWorker: boolean; isWorkerThread?: boolean; isChildProcess?: boolean; workerData: any; workerId: number; }; } } } interface AbortSignalEventTargetAddOptions { once: boolean; } interface AbortSignalEventTarget { addEventListener: (name: 'abort', listener: () => void, options?: AbortSignalEventTargetAddOptions) => void; removeEventListener: (name: 'abort', listener: () => void) => void; aborted?: boolean; } interface AbortSignalEventEmitter { off: (name: 'abort', listener: () => void) => void; once: (name: 'abort', listener: () => void) => void; } type AbortSignalAny = AbortSignalEventTarget | AbortSignalEventEmitter; type ResourceLimits = Worker extends { resourceLimits?: infer T; } ? T : object; interface Options { filename?: string | null; runtime?: 'worker_threads' | 'child_process'; name?: string; minThreads?: number; maxThreads?: number; idleTimeout?: number; terminateTimeout?: number; maxQueue?: number | 'auto'; concurrentTasksPerWorker?: number; useAtomics?: boolean; resourceLimits?: ResourceLimits; maxMemoryLimitBeforeRecycle?: number; argv?: string[]; execArgv?: string[]; env?: Record; workerData?: any; taskQueue?: TaskQueue; trackUnmanagedFds?: boolean; isolateWorkers?: boolean; } interface FilledOptions extends Options { filename: string | null; name: string; runtime: NonNullable; minThreads: number; maxThreads: number; idleTimeout: number; maxQueue: number; concurrentTasksPerWorker: number; useAtomics: boolean; taskQueue: TaskQueue; } interface RunOptions { transferList?: TransferList; channel?: TinypoolChannel; filename?: string | null; signal?: AbortSignalAny | null; name?: string | null; runtime?: Options['runtime']; } type TransferList = MessagePort extends { postMessage(value: any, transferList: infer T): any; } ? T : never; type TransferListItem = TransferList extends (infer T)[] ? T : never; declare class Tinypool extends EventEmitterAsyncResource { #private; constructor(options?: Options); run(task: any, options?: RunOptions): Promise; destroy(): Promise; get options(): FilledOptions; get threads(): TinypoolWorker[]; get queueSize(): number; cancelPendingTasks(): void; recycleWorkers(options?: Pick): Promise; get completed(): number; get duration(): number; static get isWorkerThread(): boolean; static get workerData(): any; static get version(): string; static move(val: Transferable | TransferListItem | ArrayBufferView | ArrayBuffer | MessagePort): MessagePort | ArrayBuffer | Transferable | ArrayBufferView; static get transferableSymbol(): symbol; static get valueSymbol(): symbol; static get queueOptionsSymbol(): symbol; } declare const _workerId: number; export { type Options, type ReadyMessage, type RequestMessage, type ResponseMessage, type StartupMessage, type Task, type TaskQueue, Tinypool, type TinypoolChannel, type TinypoolData, type TinypoolPrivateData, type TinypoolWorker, type TinypoolWorkerMessage, type Transferable, Tinypool as default, isMovable, isTaskQueue, isTransferable, kFieldCount, kQueueOptions, kRequestCountField, kResponseCountField, kTransferable, kValue, markMovable, _workerId as workerId };