From 345226a08f242ab2a15deda60d2ecb7c1437282b Mon Sep 17 00:00:00 2001 From: martinRenou Date: Mon, 9 Sep 2024 10:43:01 +0200 Subject: [PATCH] Fix communication with comlink worker --- src/web_worker_kernel.ts | 32 +++++++++++++++++++++++++++----- 1 file changed, 27 insertions(+), 5 deletions(-) diff --git a/src/web_worker_kernel.ts b/src/web_worker_kernel.ts index 7901923..4c19fc2 100644 --- a/src/web_worker_kernel.ts +++ b/src/web_worker_kernel.ts @@ -71,7 +71,7 @@ export class WebWorkerKernel implements IKernel { let remote: IXeusWorkerKernel | Remote; if (crossOriginIsolated) { remote = coincident(this._worker) as IXeusWorkerKernel; - remote.processWorkerMessage = this._processWorkerMessage.bind(this); + remote.processWorkerMessage = this._processCoincidentWorkerMessage.bind(this); // The coincident worker uses its own filesystem API: (remote.processDriveRequest as any) = async ( data: TDriveRequest @@ -92,7 +92,7 @@ export class WebWorkerKernel implements IKernel { }; } else { this._worker.onmessage = e => { - this._processWorkerMessage(e.data); + this._processComlinkWorkerMessage(e.data); }; remote = wrap(this._worker) as Remote; } @@ -114,7 +114,6 @@ export class WebWorkerKernel implements IKernel { } private async _sendMessageToWorker(msg: any): Promise { - // TODO Remove this?? if (msg.header.msg_type !== 'input_reply') { this._executeDelegate = new PromiseDelegate(); } @@ -149,11 +148,11 @@ export class WebWorkerKernel implements IKernel { } /** - * Process a message coming from the xeus web worker. + * Process a message coming from the coincident web worker. * * @param msg The worker message to process. */ - private _processWorkerMessage(msg: any): void { + private _processCoincidentWorkerMessage(msg: any): void { if (!msg.data?.header) { return; } @@ -171,6 +170,29 @@ export class WebWorkerKernel implements IKernel { } } + /** + * Process a message coming from the comlink web worker. + * + * @param msg The worker message to process. + */ + private _processComlinkWorkerMessage(msg: any): void { + if (!msg.header) { + return; + } + + msg.header.session = this._parentHeader?.session ?? ''; + msg.session = this._parentHeader?.session ?? ''; + this._sendMessage(msg); + + // resolve promise + if ( + msg.header.msg_type === 'status' && + msg.content.execution_state === 'idle' + ) { + this._executeDelegate.resolve(); + } + } + /** * A promise that is fulfilled when the kernel is ready. */