+import { PoolType } from '../pool-internal'
import type { ClusterPoolOptions } from './fixed'
import { FixedClusterPool } from './fixed'
*
* @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.
- *
* @author [Christopher Quadflieg](https://github.com/Shinigami92)
* @since 2.0.0
*/
* @param min Minimum number of workers which are always active.
* @param max Maximum number of workers that can be created by this pool.
* @param filePath Path to an implementation of a `ClusterWorker` file, which can be relative or absolute.
- * @param opts Options for this dynamic cluster pool. Default: `{}`
+ * @param opts Options for this dynamic cluster pool.
*/
public constructor (
min: number,
- public readonly max: number,
+ protected readonly max: number,
filePath: string,
opts: ClusterPoolOptions = {}
) {
super(min, filePath, opts)
}
- /** @inheritdoc */
- public isDynamic (): boolean {
- return true
+ /** @inheritDoc */
+ public get type (): PoolType {
+ return PoolType.DYNAMIC
+ }
+
+ /** @inheritDoc */
+ public get busy (): boolean {
+ return this.workers.length === this.max
}
}