about summary refs log tree commit diff stats
path: root/js/baba-yaga/simple-debug.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/baba-yaga/simple-debug.js')
-rw-r--r--js/baba-yaga/simple-debug.js41
1 files changed, 41 insertions, 0 deletions
diff --git a/js/baba-yaga/simple-debug.js b/js/baba-yaga/simple-debug.js
new file mode 100644
index 0000000..1d46189
--- /dev/null
+++ b/js/baba-yaga/simple-debug.js
@@ -0,0 +1,41 @@
+// simple-debug.js - Debug the test result structure
+
+import { createLexer } from './src/core/lexer.js';
+import { createParser } from './src/core/parser.js';
+import { createInterpreter } from './src/core/interpreter.js';
+
+function runBabaCode(code) {
+  const lexer = createLexer(code);
+  const tokens = lexer.allTokens();
+  const parser = createParser(tokens);
+  const ast = parser.parse();
+  
+  const host = {
+    jsBridgeConfig: {
+      allowedFunctions: new Set([
+        'JSON.parse', 'JSON.stringify',
+        'Math.abs', 'Math.floor', 'Math.ceil', 'Math.round',
+        'Math.min', 'Math.max', 'Math.random',
+        'console.log', 'console.warn', 'console.error',
+        'Date.now', 'performance.now'
+      ])
+    },
+    io: {
+      out: () => {},
+      debug: () => {}
+    }
+  };
+  
+  const interpreter = createInterpreter(ast, host);
+  interpreter.interpret();
+  return interpreter.scope.get('result');
+}
+
+const code = `result : io.callJS "Math.abs" [-42];`;
+const result = runBabaCode(code);
+
+console.log('Result:', result);
+console.log('Type:', result?.type);
+console.log('Properties:', result?.properties);
+console.log('Has Ok?', result?.properties?.has('Ok'));
+console.log('Ok value:', result?.properties?.get('Ok'));