repositories
/
poolifier.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'master' into feature/task-functions
[poolifier.git]
/
src
/
pools
/
worker.ts
diff --git
a/src/pools/worker.ts
b/src/pools/worker.ts
index 7a8c59e7730eba9be39ae972f94022a8a65a14ce..37d6308507669dd1f0ebcc295b790a1857c16a3e 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.
*/
@@
-144,7
+144,7
@@
export interface WorkerInfo {
/**
* Task function names.
*/
/**
* Task function names.
*/
- taskFunctions?: string[]
+ taskFunction
Name
s?: string[]
}
/**
}
/**
@@
-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,8
+208,13
@@
export interface IWorker {
readonly once: (event: 'exit', handler: ExitHandler<this>) => void
}
readonly once: (event: 'exit', handler: ExitHandler<this>) => void
}
-export type EmptyQueueCallback = (workerId: number) => void
-export type BackPressureCallback = EmptyQueueCallback
+/**
+ * Worker node event callback.
+ *
+ * @param workerId - The worker id.
+ * @internal
+ */
+export type WorkerNodeEventCallback = (workerId: number) => void
/**
* Worker node interface.
/**
* Worker node interface.
@@
-221,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).
*/
@@
-233,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?:
EmptyQueue
Callback
+ onBackPressure?:
WorkerNodeEvent
Callback
/**
* Callback invoked when worker node tasks queue is empty.
/**
* Callback invoked when worker node tasks queue is empty.
- *
- * @param workerId - The worker id.
*/
*/
- onEmptyQueue?:
BackPressure
Callback
+ onEmptyQueue?:
WorkerNodeEvent
Callback
/**
* Tasks queue size.
*
/**
* Tasks queue size.
*