perf: use a single map to store pool workers and their related data
[poolifier.git] / src / pools / pool-internal.ts
index e0d0534f83a846cbfac77eb87e305e0975c49abf..97e5d5d2d56ae75435b19d1ccb8afae10ff2e8ed 100644 (file)
@@ -19,6 +19,16 @@ export interface TasksUsage {
   avgRunTime: number
 }
 
+/**
+ * Internal worker type.
+ *
+ * @typeParam Worker - Type of worker which manages this pool.
+ */
+export interface WorkerType<Worker extends IPoolWorker> {
+  worker: Worker
+  tasksUsage: TasksUsage
+}
+
 /**
  * Internal contract definition for a poolifier pool.
  *
@@ -32,17 +42,9 @@ export interface IPoolInternal<
   Response = unknown
 > extends IPool<Data, Response> {
   /**
-   * List of currently available workers.
+   * Map of workers.
    */
-  readonly workers: Worker[]
-
-  /**
-   * The workers tasks usage map.
-   *
-   *  `key`: The `Worker`
-   *  `value`: Worker tasks usage statistics.
-   */
-  readonly workersTasksUsage: Map<Worker, TasksUsage>
+  readonly workers: Map<number, WorkerType<Worker>>
 
   /**
    * Pool type.
@@ -74,14 +76,6 @@ export interface IPoolInternal<
    */
   findFreeWorker: () => Worker | false
 
-  /**
-   * Gets worker index.
-   *
-   * @param worker - The worker.
-   * @returns The worker index.
-   */
-  getWorkerIndex: (worker: Worker) => number
-
   /**
    * Gets worker running tasks.
    *