X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Fpools%2Fselection-strategies%2Fabstract-worker-choice-strategy.ts;h=ebe74dcb07543b7c7698e2c2f284c33893b6e9ca;hb=7e060ceea2e476067edc0a19a02fdfd35df7bb8a;hp=cd50f700bdb74d1fe75f6f37a00d3867ece5c178;hpb=10fcfaf49c0b6d6f0e1d137eeba1e9d805c9a815;p=poolifier.git diff --git a/src/pools/selection-strategies/abstract-worker-choice-strategy.ts b/src/pools/selection-strategies/abstract-worker-choice-strategy.ts index cd50f700..ebe74dcb 100644 --- a/src/pools/selection-strategies/abstract-worker-choice-strategy.ts +++ b/src/pools/selection-strategies/abstract-worker-choice-strategy.ts @@ -1,6 +1,6 @@ -import type { AbstractPoolWorker } from '../abstract-pool-worker' import type { IPoolInternal } from '../pool-internal' import { PoolType } from '../pool-internal' +import type { IPoolWorker } from '../pool-worker' import type { IWorkerChoiceStrategy, RequiredStatistics @@ -9,18 +9,18 @@ import type { /** * Abstract worker choice strategy class. * - * @template Worker Type of worker which manages the strategy. - * @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. + * @typeParam Worker - Type of worker which manages the strategy. + * @typeParam Data - Type of data sent to the worker. This can only be serializable data. + * @typeParam Response - Type of response of execution. This can only be serializable data. */ export abstract class AbstractWorkerChoiceStrategy< - Worker extends AbstractPoolWorker, + Worker extends IPoolWorker, Data, Response > implements IWorkerChoiceStrategy { - /** @inheritDoc */ - public isDynamicPool: boolean = this.pool.type === PoolType.DYNAMIC - /** @inheritDoc */ + /** {@inheritDoc} */ + public readonly isDynamicPool: boolean + /** {@inheritDoc} */ public requiredStatistics: RequiredStatistics = { runTime: false } @@ -28,12 +28,17 @@ export abstract class AbstractWorkerChoiceStrategy< /** * Constructs a worker choice strategy attached to the pool. * - * @param pool The pool instance. + * @param pool - The pool instance. */ public constructor ( protected readonly pool: IPoolInternal - ) {} + ) { + this.isDynamicPool = this.pool.type === PoolType.DYNAMIC + } + + /** {@inheritDoc} */ + public abstract reset (): boolean - /** @inheritDoc */ + /** {@inheritDoc} */ public abstract choose (): Worker }