Files
hakorune/docs/guides/scopebox.md

35 lines
1.7 KiB
Markdown
Raw Permalink Normal View History

ScopeBox and MIR Scope Hints (Dev/CI option)
Overview
- ScopeBox is an optional, compile-time-only wrapper that makes lexical scopes explicit in the AST for diagnostics and macro visibility. It is a no-op for execution: MIR lowering treats ScopeBox like a normal block and semantics are unchanged.
How to enable
- Inject ScopeBox wrappers during core normalization by setting:
- `NYASH_SCOPEBOX_ENABLE=1`
- Selfhost compiler path: Runner maps `NYASH_SCOPEBOX_ENABLE=1` to child arg `--scopebox` and applies a JSON prepass via `apps/lib/scopebox_inject.hako`(現状は恒等: 構文確認のみ)。
- Injection points:
- If.then / If.else bodies
- Loop.body
- Bare blocks are represented by `Program { statements }` and already get ScopeEnter/ScopeLeave hints.
MIR Scope Hints (unified env)
- Configure hint output with a single env using a pipe-style syntax:
- `NYASH_MIR_HINTS="<target>|<filters>..."`
- Targets:
- `trace` or `stderr`: print human-friendly hints to stderr
- `jsonl=<path>` or a file path: append one JSON object per line
- Filters:
- `all` (default), `scope`, `join`, `loop`, `phi`
- Examples:
- `NYASH_MIR_HINTS="trace|all"`
- `NYASH_MIR_HINTS="jsonl=tmp/hints.jsonl|scope|join"`
- `NYASH_MIR_HINTS="tmp/hints.jsonl|loop"`
- Back-compat:
- `NYASH_MIR_TRACE_HINTS=1` is still accepted (equivalent to `trace|all`).
Zero-cost policy
- ScopeBox is removed implicitly during MIR lowering (treated as a block). ScopeEnter/ScopeLeave hints are observational only. Execution and IR are unchanged.
Notes (Selfhost path)
- 当面は JSON v0 に `ScopeBox` 型は導入しない互換維持。前処理は恒等identityから開始し、将来は安全な包み込み/ヒント付与を検討する。