## Phase 120: selfhost Stage-3 代表パスの安定化 (完了) ### 概要 Phase 106-115完了時点でのselfhost経路(Stage-3 .hakoコンパイラ)の 動作ベースラインを確立。実装修正なし、現状記録のみ。 ### 完了タスク - ✅ 代表パス選定: 3つの.hakoファイル選定完了 - peek_expr_block.hako (match式・ブロック式) - loop_min_while.hako (ループ・PHI命令) - esc_dirname_smoke.hako (複雑制御構造・StringBox) - ✅ 期待フロー整理: JoinIR Strict モード説明ドキュメント作成 - ✅ 実行調査完了: NYASH_JOINIR_STRICT=1 での動作確認 - ✅ ベースライン確立: 詳細実行結果記録 - ✅ スモークスクリプト作成: integration profileに統合 ### 実行結果 - ✅ 完全成功: 2/3 (peek_expr_block, loop_min_while) - ⚠️ 既知問題: 1/3 (esc_dirname_smoke - ConsoleBox.println解決失敗) ### JoinIR Strict検証結果 - ✅ If Lowering 動作 - ✅ Loop Lowering 動作 - ✅ PHI命令生成 - ✅ ControlForm構造生成 - ✅ StringBox操作 - ❌ ConsoleBox.println (メソッド解決失敗) ### Phase 122+への課題 **高優先度**: - ConsoleBox.printlnメソッド解決エラー修正 **中優先度**: - NYASH_PARSER_STAGE3非推奨警告対応 **低優先度**: - builtin Box プラグイン移行検討 ### 技術的成果 - Phase 106-115の安定性確認完了 - JoinIR Lowering動作確認 - 明確なPhase 122+タスクリスト確立 - 回帰検証可能なテスト整備 ### ファイル構成 **新規作成**: - docs/development/current/main/phase120_selfhost_stable_paths.md (指示書) - docs/development/current/main/selfhost_stage3_expected_flow.md (期待フロー) - docs/development/current/main/phase120_baseline_results.md (ベースライン結果) - tools/smokes/v2/profiles/integration/selfhost/phase120_stable_paths.sh (スモークテスト) **修正**: - CURRENT_TASK.md (Phase 120完了記録追加) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
Hakorune Smoke Tests v2 — Guide (Nyash-compatible)
Overview
- Entry:
tools/smokes/v2/run.sh— unified runner for quick/integration/full. - Profiles:
quick— fast developer checks.integration— VM↔LLVM parity, basic stability.full— comprehensive matrix.
🎯 Two Baselines (Runbook)
これから開発の基準となる2つのベースライン:
📦 VM ライン(Rust VM - 既定)
用途: 開発・デバッグ・検証用(高速・型安全)
# ビルド
cargo build --release
# 一括スモークテスト
tools/smokes/v2/run.sh --profile quick
# 個別スモークテスト
tools/smokes/v2/run.sh --profile quick --filter "<glob>"
# 例: --filter "core/json_query_min_vm.sh"
# 単発実行(参考)
$NYASH_BIN --backend vm apps/APP/main.hako
⚡ llvmlite ライン(LLVMハーネス)
用途: 本番・最適化・配布用(実証済み安定性)
前提: Python3 + llvmlite
pip install llvmlite # 未導入の場合
実行手順:
# ビルド(LLVM_SYS_180_PREFIX不要!)
cargo build --release --features llvm
# 一括スモークテスト
tools/smokes/v2/run.sh --profile integration
# 個別スモークテスト
tools/smokes/v2/run.sh --profile integration --filter "<glob>"
# 単発実行
NYASH_LLVM_USE_HARNESS=1 $NYASH_BIN --backend llvm apps/tests/peek_expr_block.hako
# 有効化確認
$NYASH_BIN --version | rg -i 'features.*llvm'
💡 重要: 両方のラインのテストが通ることで、MIR14統一アーキテクチャの品質を保証!
🔁 QuickでAST/LLVM系も実行したいとき
通常、quick は LLVM未ビルド時に AST/LLVM系テストを自動で SKIP します。
Quickでも実行したい場合は、先に LLVM 有効でビルドしてください:
LLVM_SYS_180_PREFIX=$(llvm-config-18 --prefix) cargo build --release --features llvm
tools/smokes/v2/run.sh --profile quick
テストランナーは LLVM 非対応時にヒントを出力します(buildコマンドの案内)。
Notes
- Using resolution: prefer nyash.toml aliases (SSOT). Some tests may enable
NYASH_ALLOW_USING_FILE=1internally for convenience. - Plugin warnings are informational; smokes are designed to pass without dynamic plugins.
- Harness single-run may take longer due to link+exec; integration profile includes generous timeouts.
- Binary selection in scripts: always use
$NYASH_BIN(the runner sets it totarget/release/hakorunewhen present, otherwise falls back tonyash). - Branding: user‑visible messages prefer “Hakorune”; the legacy
nyashbinary remains for compatibility but may be gated(HAKO_ALLOW_NYASH=1)。
Dev Mode (defaults)
- In v2 smokes, the
quickprofile exportsNYASH_DEV=1by default.- This enables CLI
--dev-equivalent defaults inside Nyash:- AST using ON (SSOT + AST prelude merge)
- Operator Boxes in observe mode (no adoption)
- Minimal diagnostics; output parity is preserved
- This enables CLI
- You can also run manually with
nyash --dev script.hako.
Common commands
- Quick suite (auto
NYASH_DEV=1):tools/smokes/v2/run.sh --profile quick
- Focus JSON smokes:
tools/opbox-json.sh(Roundtrip/Nested, plugins disabled, generous timeout)
- One-off program (VM):
$NYASH_BIN --backend vm --dev apps/APP/main.hako
Key env knobs
NYASH_DEV=1— enable dev defaults (same effect as--dev).SMOKES_DEFAULT_TIMEOUT— per test timeout seconds (default 15 for quick).SMOKES_PLUGIN_MODE=dynamic|static— plugin mode for preflight (auto by default).SMOKES_FORCE_CONFIG=rust_vm_dynamic|llvm_static— force backend config.SMOKES_NOTIFY_TAIL— lines to show on failure tail (default 80).
Notes
- Dev defaults are designed to be non-intrusive: tests remain behavior‑compatible.
- To repro outside smokes, either pass
--devor exportNYASH_DEV=1.
Heavy JSON probes
- Heavy JSON tests (nested/roundtrip/query_min) run a tiny parser probe first.
- The probe's stdout last non-empty line is trimmed and compared to
ok. - If not
ok, the test is SKIP (parser unavailable), not FAIL. This avoids false negatives due to environment noise or optional dependencies.