X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Fpools%2Fpool.ts;h=752045829214f76681f92d36fce414c581fd0c95;hb=897beca72d8ea0b909f5c9cd6deb8c5e58b1dd7f;hp=0c9b232f2bca650dc6f7aed065f15e6e0061a99d;hpb=c97c7edb14ea0699cd82bce5d0ffe50ae26af667;p=poolifier.git diff --git a/src/pools/pool.ts b/src/pools/pool.ts index 0c9b232f..75204582 100644 --- a/src/pools/pool.ts +++ b/src/pools/pool.ts @@ -1,9 +1,27 @@ -export interface IPool< - // eslint-disable-next-line @typescript-eslint/no-explicit-any - Data = any, - // eslint-disable-next-line @typescript-eslint/no-explicit-any - Response = any -> { - destroy(): Promise +import type { WorkerChoiceStrategy } from './selection-strategies' + +/** + * Contract definition for a poolifier pool. + * + * @template Data Type of data sent to the worker. This can only be serializable data. + * @template Response Type of response of execution. This can only be serializable data. + */ +export interface IPool { + /** + * Perform the task specified in the constructor with the data parameter. + * + * @param data The input for the specified task. This can only be serializable data. + * @returns Promise that will be resolved when the task is successfully completed. + */ execute(data: Data): Promise + /** + * Shut down every current worker in this pool. + */ + destroy(): Promise + /** + * Set the worker choice strategy in this pool. + * + * @param workerChoiceStrategy The worker choice strategy. + */ + setWorkerChoiceStrategy(workerChoiceStrategy: WorkerChoiceStrategy): void }