about summary refs log tree commit diff stats
path: root/js/baba-yaga/debug-property.js
blob: 97bb0cbb66cd4fb8bfa1676f37532b1e62f9a7ae (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
// debug-property.js - Debug property access test

import { createLexer } from './src/core/lexer.js';
import { createParser } from './src/core/parser.js';
import { createInterpreter } from './src/core/interpreter.js';

const code = `
  jsObj : io.callJS "JSON.parse" ["{\\"x\\": 42, \\"y\\": 24}"];
  result : when jsObj is
    Ok obj then io.getProperty obj "x"
    Err msg then Err msg;
  result;
`;

console.log('Code:', 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: (...args) => console.log('[OUT]', ...args),
    debug: (...args) => console.log('[DEBUG]', ...args)
  }
};

const interpreter = createInterpreter(ast, host);
interpreter.interpret();

console.log('All variables in scope:');
for (const [key, value] of interpreter.scope.entries()) {
  console.log(`  ${key}:`, value);
}

const result = interpreter.scope.get('result');
console.log('Final result:', result);