diff --git a/docs/dist/App.js b/docs/dist/App.js index 86d580ab..98d2a884 100644 --- a/docs/dist/App.js +++ b/docs/dist/App.js @@ -43,9 +43,7 @@ function App() { return []; } }, [pattern]), - onSchedule: useCallback((_events, cycle2) => { - logCycle(_events, cycle2); - }, [pattern]), + onSchedule: useCallback((_events, cycle2) => logCycle(_events, cycle2), [pattern]), ready: !!pattern }); useEffect(() => { @@ -57,8 +55,12 @@ function App() { } catch (err) { setMode("javascript"); _pattern = parse(code); + if (_pattern?.constructor?.name !== "Pattern") { + const message = `got "${typeof _pattern}" instead of pattern`; + throw new Error(message + (typeof _pattern === "function" ? "did you foget to call a function?" : "")); + } } - setPattern(_pattern); + setPattern(() => _pattern); setError(void 0); } catch (err) { console.warn(err); diff --git a/repl/src/App.tsx b/repl/src/App.tsx index 52d8bf82..faad502a 100644 --- a/repl/src/App.tsx +++ b/repl/src/App.tsx @@ -53,31 +53,26 @@ function App() { }, [pattern] ), - onSchedule: useCallback( - (_events, cycle) => { - // console.log('schedule', _events, cycle); - logCycle(_events, cycle); - }, - [pattern] - ), + onSchedule: useCallback((_events, cycle) => logCycle(_events, cycle), [pattern]), ready: !!pattern, }); // parse pattern when code changes useEffect(() => { try { - let _pattern; + let _pattern: Pattern; try { _pattern = h(code); setMode('pegjs'); // haskell mode does not recognize quotes, pegjs looks ok by accident.. - // console.log('h _pattern', _pattern); } catch (err) { setMode('javascript'); // code is not haskell like _pattern = parse(code); - // console.log('not haskell..', _pattern); + if (_pattern?.constructor?.name !== 'Pattern') { + const message = `got "${typeof _pattern}" instead of pattern`; + throw new Error(message + (typeof _pattern === 'function' ? ', did you forget to call a function?' : '.')); + } } - setPattern(_pattern); - // cycle.query(cycle.activeCycle()); // reschedule active cycle + setPattern(() => _pattern); // need arrow function here! otherwise if user returns a function, react will think it's a state reducer setError(undefined); } catch (err: any) { console.warn(err);