Skip to content

Commit

Permalink
try to fix broken expressions
Browse files Browse the repository at this point in the history
(in production) - fixes #2059
also type
and log worker error early
  • Loading branch information
mifi committed Aug 6, 2024
1 parent 0a38398 commit 6e60133
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 12 deletions.
38 changes: 31 additions & 7 deletions src/renderer/src/worker/eval.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,28 @@
const workerUrl = new URL('evalWorker.js', import.meta.url);
import invariant from 'tiny-invariant';

// https://github.com/vitejs/vite/issues/11823#issuecomment-1407277242
// https://github.com/mifi/lossless-cut/issues/2059
import Worker from './evalWorker?worker';


export interface RequestMessageData {
code: string,
id: number,
context: string // json
}

export type ResponseMessageData = { id: number } & ({
error: string,
} | {
data: unknown,
})

// https://v3.vitejs.dev/guide/features.html#web-workers
// todo terminate() and recreate in case of error?
const worker = new Worker(workerUrl);
const worker = new Worker();
worker.addEventListener('error', (err) => {
console.error('evalWorker error', err);
});

let lastRequestId = 0;

Expand All @@ -22,13 +42,17 @@ export default async function safeishEval(code: string, context: Record<string,
worker.removeEventListener('error', onError);
}

function onMessage({ data: { id: responseId, error, data } }) {
function onMessage(response: { data: ResponseMessageData }) {
// console.log('message', { responseId, error, data })

if (responseId === id) {
if (response.data.id === id) {
cleanup();
if (error) reject(new Error(error));
else resolve(data);
if ('error' in response.data) {
reject(new Error(response.data.error));
} else {
invariant('data' in response.data);
resolve(response.data.data);
}
}
}

Expand All @@ -46,6 +70,6 @@ export default async function safeishEval(code: string, context: Record<string,
worker.addEventListener('messageerror', onMessageerror);
worker.addEventListener('error', onError);

worker.postMessage({ id, code, context: JSON.stringify(context) });
worker.postMessage({ id, code, context: JSON.stringify(context) } satisfies RequestMessageData);
});
}
15 changes: 10 additions & 5 deletions src/renderer/src/worker/evalWorker.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,15 @@
// eslint-disable-next-line unicorn/no-this-assignment, @typescript-eslint/no-this-alias
const myGlobal = this;
import type { RequestMessageData, ResponseMessageData } from './eval';


// https://stackoverflow.com/a/10796616/6519037
// https://github.com/Zirak/SO-ChatBot/blob/master/source/eval.js
// https://github.com/Zirak/SO-ChatBot/blob/master/source/codeWorker.js

// `this` doesn't seem to work when transpiling, so use globalThis instead
// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/globalThis
const myGlobal = globalThis;


const wl = {
self: 1,
onmessage: 1,
Expand Down Expand Up @@ -119,7 +124,7 @@ myGlobal.fetch = undefined;

// eslint-disable-next-line wrap-iife, func-names
(function () {
onmessage = (event) => {
onmessage = (event: MessageEvent<RequestMessageData>) => {
// eslint-disable-next-line strict, lines-around-directive
'use strict';

Expand All @@ -130,9 +135,9 @@ myGlobal.fetch = undefined;
// https://stackoverflow.com/questions/8403108/calling-eval-in-particular-context
// eslint-disable-next-line unicorn/new-for-builtins, no-new-func
const result = Function(`\nwith (this) { return (${code}); }`).call(context);
postMessage({ id, data: result });
postMessage({ id, data: result } satisfies ResponseMessageData);
} catch (e) {
postMessage({ id, error: `${e}` });
postMessage({ id, error: `${e}` } satisfies ResponseMessageData);
}
};
})();
2 changes: 2 additions & 0 deletions tsconfig.web.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@
"noEmit": true,

"noImplicitAny": false, // todo

"types": ["vite/client"],
},
"references": [
{ "path": "./tsconfig.main.json" },
Expand Down

0 comments on commit 6e60133

Please sign in to comment.