- Add HAKO_TRACE_EXECUTION to trace executor route - Rust hv1_inline: stderr [trace] executor: hv1_inline (rust) - Hakovm dispatcher: stdout [trace] executor: hakovm (hako) - test_runner: trace lines for hv1_inline/core/hakovm routes - Add HAKO_VERIFY_SHOW_LOGS and HAKO_DEBUG=1 (enables both) - verify_v1_inline_file() log passthrough with numeric rc extraction - test_runner exports via HAKO_DEBUG - Canary expansion under phase2170 (state spec) - Array: push×5/10 → size, len/length alias, per‑recv/global, flow across blocks - Map: set dup-key non-increment, value_state get/has - run_all.sh: unify, remove SKIPs; all PASS - Docs - ENV_VARS.md: add Debug/Tracing toggles and examples - PLAN.md/CURRENT_TASK.md: mark 21.7 green, add Quickstart lines All changes gated by env vars; default behavior unchanged.
35 lines
1013 B
Bash
35 lines
1013 B
Bash
#!/usr/bin/env bash
|
|
set -euo pipefail
|
|
|
|
ROOT="$(cd "$(dirname "$0")/../.." && pwd)"
|
|
BIN="${NYASH_BIN:-$ROOT/target/release/hakorune}"
|
|
if [ ! -x "$BIN" ]; then
|
|
echo "[DOT] hakorune not built: $BIN" >&2
|
|
exit 2
|
|
fi
|
|
|
|
TMP_HAKO="/tmp/dot_edges_$$.hako"
|
|
cat >"$TMP_HAKO" <<'HK'
|
|
// Minimal two boxes with a call to form one edge
|
|
static box Helper {
|
|
method echo(msg) { return 0 }
|
|
}
|
|
static box Main {
|
|
method main() {
|
|
Helper.echo("hi")
|
|
return 0
|
|
}
|
|
}
|
|
HK
|
|
|
|
export LD_LIBRARY_PATH="${ROOT}/target/release:${LD_LIBRARY_PATH:-}"
|
|
OUT=$(
|
|
NYASH_DISABLE_NY_COMPILER=1 HAKO_DISABLE_NY_COMPILER=1 \
|
|
NYASH_PARSER_STAGE3=1 HAKO_PARSER_STAGE3=1 \
|
|
NYASH_DISABLE_PLUGINS=1 NYASH_BOX_FACTORY_POLICY=builtin_first \
|
|
"$BIN" --backend vm "$ROOT/tools/hako_check/cli.hako" -- --format dot --source-file "$TMP_HAKO" "$(sed 's/\r$//' "$TMP_HAKO")"
|
|
)
|
|
echo "$OUT" | sed -n '1,80p'
|
|
echo "$OUT" | grep -q '"Main.main/0" -> "Helper.echo/1";' && echo "[DOT] edge OK" || { echo "[DOT] edge MISSING" >&2; exit 1; }
|
|
rm -f "$TMP_HAKO"
|