From 0eb97783fce6caf18171a3bfe898babe2de6a4cb Mon Sep 17 00:00:00 2001 From: sapphi-red <49056869+sapphi-red@users.noreply.github.com> Date: Wed, 4 Dec 2024 12:55:52 +0900 Subject: [PATCH] fix: make handleInvoke interface compatible with invoke --- packages/vite/src/node/server/hmr.ts | 12 +++++++++--- packages/vite/src/node/server/ws.ts | 2 +- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/packages/vite/src/node/server/hmr.ts b/packages/vite/src/node/server/hmr.ts index fa15d0895803bf..d286f4d2ed3597 100644 --- a/packages/vite/src/node/server/hmr.ts +++ b/packages/vite/src/node/server/hmr.ts @@ -157,7 +157,7 @@ export interface NormalizedHotChannel { off(event: string, listener: Function): void /** @internal */ setInvokeHandler(invokeHandlers: InvokeMethods | undefined): void - handleInvoke(payload: HotPayload): Promise<{ r: any } | { e: any }> + handleInvoke(payload: HotPayload): Promise<{ result: any } | { error: any }> /** * Start listening for messages */ @@ -301,7 +301,13 @@ export const normalizeHotChannel = ( } channel.on?.('vite:invoke', listenerForInvokeHandler) }, - handleInvoke, + handleInvoke: async (payload) => { + const data = await handleInvoke(payload) + if (data.e) { + return { error: data.e } + } + return { result: data.r } + }, send: (...args: any[]) => { let payload: HotPayload if (typeof args[0] === 'string') { @@ -1161,7 +1167,7 @@ export function createDeprecatedHotBroadcaster( send: ws.send, setInvokeHandler: ws.setInvokeHandler, handleInvoke: async () => ({ - e: { + error: { name: 'TransportError', message: 'handleInvoke not implemented', stack: new Error().stack, diff --git a/packages/vite/src/node/server/ws.ts b/packages/vite/src/node/server/ws.ts index 8b8081f43bfbb7..6e7ca804fbae72 100644 --- a/packages/vite/src/node/server/ws.ts +++ b/packages/vite/src/node/server/ws.ts @@ -105,7 +105,7 @@ export function createWebSocketServer( off: noop as any as WebSocketServer['off'], setInvokeHandler: noop, handleInvoke: async () => ({ - e: { + error: { name: 'TransportError', message: 'handleInvoke not implemented', stack: new Error().stack,