From 454ac00ae6ed814f43e7da0a10345bc342841295 Mon Sep 17 00:00:00 2001 From: loucadufault <40028187+loucadufault@users.noreply.github.com> Date: Wed, 4 Dec 2024 14:34:13 +0000 Subject: [PATCH] handle errors emitted by xkeys during init process before the instance is exposed to the caller --- packages/node/src/methods.ts | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/packages/node/src/methods.ts b/packages/node/src/methods.ts index 9f22cb1..7942ac2 100644 --- a/packages/node/src/methods.ts +++ b/packages/node/src/methods.ts @@ -116,6 +116,34 @@ export async function setupXkeysPanel( // Wait for the device to initialize: await xkeys.init() + let alreadyRejected = false + await new Promise((resolve, reject) => { + const markRejected = (e: unknown) => { + reject(e) + alreadyRejected = true + } + const xkeysStopgapErrorHandler = (e: unknown) => { + if (alreadyRejected) { + console.error(`Xkeys: Error emitted after setup already rejected:`, e) + return + } + + markRejected(e) + } + + // Handle all error events until the instance is returned + xkeys.on('error', xkeysStopgapErrorHandler) + + // Wait for the device to initialize: + xkeys + .init() + .then(() => { + resolve() + xkeys.removeListener('error', xkeysStopgapErrorHandler) + }) + .catch(markRejected) + }) + return xkeys } catch (e) { if (device) await device.close().catch(() => null) // Suppress error