docs: add MIR13 mode doc and set PHI-off as default; bridge lowering split (if/loop/try); llvmlite resolver stabilization; curated runner default PHI-off; refresh CURRENT_TASK.md
This commit is contained in:
45
docs/development/refactoring/candidates_phase15.md
Normal file
45
docs/development/refactoring/candidates_phase15.md
Normal file
@ -0,0 +1,45 @@
|
||||
# Refactoring Candidates — Phase 15 (Mainline only)
|
||||
|
||||
Scope: PyVM/LLVM/Runner mainline. JIT/Cranelift is explicitly out of scope for this pass.
|
||||
|
||||
Goals
|
||||
- Improve maintainability and locality of logic in the primary execution paths.
|
||||
- Reduce ad-hoc env access; prefer `src/config/env.rs` helpers.
|
||||
- Clarify control-flow lowering responsibilities in LLVM codegen.
|
||||
|
||||
High‑Value Candidates
|
||||
- Runner CLI directives
|
||||
- Extract header‐comment directives scanning from `runner/mod.rs` → `runner/cli_directives.rs` (done).
|
||||
- Next: Move using/alias/env merge traces behind a `runner::trace` helper to keep `mod.rs` slim.
|
||||
|
||||
- LLVM codegen structure
|
||||
- Introduce `instructions/terminators.rs` (return/jump/branch emit glue) and `instructions/select.rs` (cond/short‑circuit pre‑normalize). Initially re‑export from `flow.rs`; later migrate implementations.
|
||||
- Keep `function.rs` focused on BB visitation + delegations (no heavy logic inline).
|
||||
|
||||
- VM dispatch integration
|
||||
- Gradually route the big `match` in VM through `backend/dispatch.rs` (already scaffolded). Start with side‑effect‑free ops (Const/Compare/TypeOp) to de‑risk.
|
||||
- Add opt‑in flag `NYASH_VM_USE_DISPATCH=1` to gate behavior during the transition.
|
||||
|
||||
- Env access centralization
|
||||
- Replace scattered `std::env::var("NYASH_*")` with `config::env` getters in hot paths (VM tracing, GC barriers, resolver toggles).
|
||||
- Add tiny wrappers where a tri‑state is needed (off/soft/on).
|
||||
|
||||
- MIR builder granularity (non‑breaking)
|
||||
- Extract loop helpers: `mir/builder/loops.rs` (headers/exits/latch snapshot utilities).
|
||||
- Extract phi helpers: `mir/builder/phi.rs` (if‑else merge, header normalize for latch).
|
||||
|
||||
Low‑Risk Cleanups
|
||||
- Tools scripts: dedupe `tools/*smoke*.sh` into `tools/smokes/` with common helpers (env, timeout, exit filtering).
|
||||
- Tests naming: prefer `*_test.rs` and `apps/tests/*.nyash` consistency for smokes.
|
||||
- Logging: add `NYASH_CLI_VERBOSE` guards consistently; provide `runner::trace!(...)` macro for concise on/off.
|
||||
|
||||
Suggested Sequencing
|
||||
1) Runner small extractions (directives/trace). Validate with existing smokes.
|
||||
2) LLVM `terminators.rs`/`select.rs` scaffolding + staged migration; zero behavior change initially.
|
||||
3) VM dispatch gating: land flag and migrate 3–5 simple opcodes; parity by unit tests.
|
||||
4) MIR builder helpers: extract without API changes; run PyVM/LLVM curated smokes.
|
||||
|
||||
Notes
|
||||
- Keep JIT/Cranelift untouched in this phase to avoid drift from the mainline policy.
|
||||
- Prefer file‑level docs on new modules to guide incremental migration.
|
||||
|
||||
Reference in New Issue
Block a user