repositories
/
poolifier.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
build(deps): bump actions/checkout from 3 to 4
[poolifier.git]
/
src
/
pools
/
worker.ts
diff --git
a/src/pools/worker.ts
b/src/pools/worker.ts
index bfd73325c3204d48c656924367500b9f30efbc1d..29050455088c6efd49d8147aed07c41f2a5a004e 100644
(file)
--- a/
src/pools/worker.ts
+++ b/
src/pools/worker.ts
@@
-132,7
+132,7
@@
export interface WorkerInfo {
/**
* Worker type.
*/
/**
* Worker type.
*/
- type: WorkerType
+
readonly
type: WorkerType
/**
* Dynamic flag.
*/
/**
* Dynamic flag.
*/
@@
-171,6
+171,15
@@
export interface WorkerUsage {
readonly elu: EventLoopUtilizationMeasurementStatistics
}
readonly elu: EventLoopUtilizationMeasurementStatistics
}
+/**
+ * Worker choice strategy data.
+ *
+ * @internal
+ */
+export interface StrategyData {
+ virtualTaskEndTimestamp?: number
+}
+
/**
* Worker interface.
*/
/**
* Worker interface.
*/
@@
-199,6
+208,14
@@
export interface IWorker {
readonly once: (event: 'exit', handler: ExitHandler<this>) => void
}
readonly once: (event: 'exit', handler: ExitHandler<this>) => void
}
+/**
+ * Worker node event callback.
+ *
+ * @param workerId - The worker id.
+ * @internal
+ */
+export type WorkerNodeEventCallback = (workerId: number) => void
+
/**
* Worker node interface.
*
/**
* Worker node interface.
*
@@
-218,7
+235,12
@@
export interface IWorkerNode<Worker extends IWorker, Data = unknown> {
/**
* Worker usage statistics.
*/
/**
* Worker usage statistics.
*/
- usage: WorkerUsage
+ readonly usage: WorkerUsage
+ /**
+ * Worker choice strategy data.
+ * This is used to store data that is specific to the worker choice strategy.
+ */
+ strategyData?: StrategyData
/**
* Message channel (worker_threads only).
*/
/**
* Message channel (worker_threads only).
*/
@@
-230,16
+252,12
@@
export interface IWorkerNode<Worker extends IWorker, Data = unknown> {
tasksQueueBackPressureSize: number
/**
* Callback invoked when worker node tasks queue is back pressured.
tasksQueueBackPressureSize: number
/**
* Callback invoked when worker node tasks queue is back pressured.
- *
- * @param workerId - The worker id.
*/
*/
- onBackPressure?:
(workerId: number) => void
+ onBackPressure?:
WorkerNodeEventCallback
/**
* Callback invoked when worker node tasks queue is empty.
/**
* Callback invoked when worker node tasks queue is empty.
- *
- * @param workerId - The worker id.
*/
*/
- onEmptyQueue?:
(workerId: number) => void
+ onEmptyQueue?:
WorkerNodeEventCallback
/**
* Tasks queue size.
*
/**
* Tasks queue size.
*