X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Fpools%2Fthread%2Ffixed.ts;h=7d47e81ae937abe695a87841babed4011873fc7a;hb=daa30e0e21087d1a3cf24b3dd38f703b1aba6d46;hp=2ad94a7bf16083072bf1303745834c2b7c06506a;hpb=103057eedf4f7b18f009333806d0293bfb23e204;p=poolifier.git diff --git a/src/pools/thread/fixed.ts b/src/pools/thread/fixed.ts index 2ad94a7b..7d47e81a 100644 --- a/src/pools/thread/fixed.ts +++ b/src/pools/thread/fixed.ts @@ -63,7 +63,7 @@ export class FixedThreadPool< const workerNode = this.workerNodes[workerNodeKey] const worker = workerNode.worker const waitWorkerExit = new Promise(resolve => { - worker.on('exit', () => { + worker.once('exit', () => { resolve() }) }) @@ -82,7 +82,7 @@ export class FixedThreadPool< ( this.workerNodes[workerNodeKey].messageChannel as MessageChannel ).port1.postMessage( - { ...message, workerId: this.workerNodes[workerNodeKey].info.id }, + { ...message, workerId: this.getWorkerInfo(workerNodeKey).id }, transferList ) } @@ -95,7 +95,7 @@ export class FixedThreadPool< workerNode.worker.postMessage( { ready: false, - workerId: workerNode.info.id, + workerId: this.getWorkerInfo(workerNodeKey).id, port: port2 }, [port2] @@ -112,6 +112,26 @@ export class FixedThreadPool< ).port1.on('message', listener) } + /** @inheritDoc */ + protected registerOnceWorkerMessageListener( + workerNodeKey: number, + listener: (message: MessageValue) => void + ): void { + ( + this.workerNodes[workerNodeKey].messageChannel as MessageChannel + ).port1.once('message', listener) + } + + /** @inheritDoc */ + protected deregisterWorkerMessageListener( + workerNodeKey: number, + listener: (message: MessageValue) => void + ): void { + ( + this.workerNodes[workerNodeKey].messageChannel as MessageChannel + ).port1.off('message', listener) + } + /** @inheritDoc */ protected createWorker (): Worker { return new Worker(this.filePath, {