- MIRビルダーのモジュール化完了(1,547行→6モジュール) - core.rs (205行): MirBuilder本体 - expressions.rs (621行): 式変換処理 - statements.rs (165行): 文変換処理 - control_flow.rs (194行): 制御フロー - box_handlers.rs (73行): Box処理 - 現在builder_modularizedに退避(MIR命令構造変更により調整必要) - フルビルド可能な状態を維持 - CURRENT_TASK.mdに引き継ぎポイント記載 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
13 KiB
13 KiB
🎯 CURRENT TASK - 2025年8月25日(状況整理)
🚨 現在の状況(2025-08-25)
✅ 完了したタスク
-
✅ MIRビルダーリファクタリング完了🎉(2025-08-25)
- mir/builder.rs: 1547行の大規模モジュール → モジュール分割完了
- 新構造:
src/mir/builder/ディレクトリmod.rs: 公開API定義core.rs: MirBuilder本体 + コア機能 (205行)expressions.rs: 式変換処理 (621行) - 18関数実装済みstatements.rs: 文変換処理 (165行) - 6関数実装済みcontrol_flow.rs: 制御フロー構築 (194行) - 4関数実装済みbox_handlers.rs: Box関連処理 (73行) - 2関数実装済み
- ビルド確認: 新構造でコンパイル正常完了 ✅
- 総移動関数数: 30関数(ヘルパー関数含む)
- 行数削減: 元の1547行から分割により読みやすさ大幅向上
- コミット完了:
- Phase 3-5: cc2a5c2 (expressions.rs)
- Phase 6-8: 29af5e1 (statements/control_flow/box_handlers)
-
✅ VMモジュールのリファクタリング完了(2025-08-25)
- execute_instruction関数を29個のハンドラーに分割
- vm_instructions.rsモジュール作成(487行)
- execute_instruction_old削除(691行削減)
- vm.rs: 2075行→1382行(33%削減)
🎯 次の優先タスク
-
copilot_issues.txtの確認
- Phase 8.4: AST→MIR Lowering完全実装(最優先)
- Phase 8.5: MIRダイエット(35命令→20命令)
- Phase 8.6: VM性能改善(0.9倍 → 2倍以上)
-
MIR26命令対応
- TypeOp/WeakRef/Barrierのプリンタ拡張
- スナップショット整備
- vm-stats差分確認
-
Builder適用拡大
- 言語
is/as導線の実装 - 弱参照フィールドのWeakLoad/WeakNew対応
- 関数スタイル
isType/asTypeの早期lowering強化
- 言語
⚠️ MIRビルダー引き継ぎポイント(ChatGPT5さんへ)
- 状況: MIRビルダーのモジュール化完了(Phase 1-8コミット済み)
- 問題: MIR命令構造の変更により、expressions.rsでエラー発生
Call命令:function→func,arguments→argsArrayAccess,ArrayLiteral,Awaitノードが削除?- effectsフィールドの有無が命令により異なる
- TypeOpKindのインポートパスエラー
- loop_builder.rsでのプライベートフィールドアクセス問題
- 現在の対応:
- builder_modularizedディレクトリに一時退避
- 元のbuilder.rsでフルビルド可能な状態に復帰
- ChatGPT5さんのMIR命令変更に合わせた調整が必要
- VMの既知の問題
- 論理演算子(and, or)がBinOpとして未実装
- エラー:
Type error: Unsupported binary operation: And on Bool(true) and Bool(false) - インタープリターでは動作するがVMで動作しない
- 新発見: BoxRef(IntegerBox) + BoxRef(IntegerBox)のような演算も未対応
- execute_binary_opにBoxRef同士の演算ケースが不足
✅ 直近の完了
- VMモジュールのリファクタリング完了(2025-08-25)
- execute_instruction関数を29個のハンドラーに分割
- vm_instructions.rsモジュール作成(487行)
- execute_instruction_old削除(691行削減)
- vm.rs: 2075行→1382行(33%削減)
- ドキュメント再編成の完了(構造刷新)
- VM×プラグインのE2E整備(FileBox/Net)
- FileBox: open/write/read, copyFrom(handle)(VM)
- Net: GET/POST(VM)、404/500(Ok(Response))、unreachable(Err(ErrorBox))
- VM命令カウンタ+時間計測のCLI化(
--vm-stats,--vm-stats-json)とJSON出力対応- サンプル/スクリプト整備(tools/run_vm_stats.sh、local_tests/vm_stats_*.nyash)
- MIR if-merge 修正(retがphi dstを返す)+ Verifier強化(mergeでのphi未使用検知、支配関係チェック導入)
- VMの健全化(分岐・比較・Result)
- Compare: Void/BoolのEq/Ne定義(順序比較はTypeError)
- Branch条件:
BoxRef(BoolBox)→bool/BoxRef(VoidBox)→false/Integer≠0→true - ResultBox: 新旧両実装への動的ディスパッチ統一(isOk/getValue/getError)
- VMビルトイン強化(Array/Map/Socket)
- ArrayBox/MapBox: 代表メソッドをVM統合ディスパッチで実装(push/get/set/size等)
- SocketBox:
acceptTimeout(ms)(void)/recvTimeout(ms)(空文字)を追加 - E2E追加:
socket_timeout_server.nyash/socket_timeout_client.nyash
- E2E拡張(Net/Socket)
- HTTP: 大ボディ取得クライアント
local_tests/http_big_body_client.nyash - Socket: 反復タイムアウト検証
local_tests/socket_repeated_timeouts.nyash - インタープリタ: SocketBoxの
acceptTimeout/recvTimeoutを結線
- HTTP: 大ボディ取得クライアント
- VM/MIRの健全化(Builder/VM)
- Compare拡張: Float/Int-Float混在をサポート(Eq/Ne/Lt/Le/Gt/Ge)
- TypeOp(Check)最小意味論実装(Integer/Float/Bool/String/Void/Box名)
- ArrayGet/ArraySet(VM)本実装(ArrayBox.get/setへ橋渡し)
- Array/Mapをidentity扱い(clone_or_shareがshareを選択)
- BoxCallにArrayBox fast-path(BoxRefからget/set直呼び)
- me参照の安定化(fallback時に一度だけConstを発行しvariable_mapに保持)
- デバッグ:
NYASH_VM_DEBUG_BOXCALL=1でBoxCallの受け手/引数/経路/結果型を標準エラーに出力
- ドキュメント追加・更新
- MIR→VMマッピング(分岐条件の動的変換、Void/Bool比較)
- VM README(SocketBoxタイムアウト/E2E導線・HTTP Result整理)
- 26命令ダイエット: PoCフラグと進捗追記(TypeOp/WeakRef/Barrier)
- CI: plugins E2E ジョブ(Linux)を追加
📊 大規模ファイルのリファクタリング候補
- src/interpreter/objects.rs (1,272行) - オブジェクト処理の分割
- src/interpreter/plugin_loader.rs (1,217行) - v2があるので削除候補?
- src/interpreter/expressions/calls.rs (1,016行) - 関数呼び出し処理の分割
🚧 次にやること(再開方針)
-
MIR26 前進(短期)
- プリンタ拡張:
TypeOp/WeakRef/Barrierを--mir-verboseに明示表示 - スナップショット整備: 代表ケースで flag ON/OFF のMIR差分固定化
- vm-stats差分:
weak_field_poc.nyash等で JSON 取得・比較(キー: TypeOp/WeakRef/Barrier) - 旗:
mir_typeop_poc(TypeCheck/Cast→TypeOp)、mir_refbarrier_unify_poc(Weak*/Barrier→統合)
- プリンタ拡張:
-
Builder適用拡大(短期〜中期)
- 言語
is/as導線(最小でも擬似ノード)→emit_type_check/emit_castへ配線 - 弱参照: 既存の
RefGet/RefSetパスは弱フィールドでWeakLoad/WeakNew+Barrier(flag ONで統合命令) - 関数スタイル
isType/asTypeの早期loweringを強化(Literal("T")とnew StringBox("T")を確実に検出) print(isType(...))の未定義SSA回避(print直前で必ずTypeOpのdstを生成)
- 言語
-
VM/Verifierの補強(中期)
TypeOp(Cast)の数値キャスト(Int/Float)安全化、誤用時TypeError整備- Verifierに26命令整合(Barrier位置、WeakRef整合、支配関係)チェックを追加
-
VM×プラグインE2Eの維持(短期)
- HTTP/Socketの回帰確認(Void防御・遅延サーバ軽量化は済)
- 必要に応じて
VM_README.mdにTips追記
-
BoxCall高速化(性能段階)
--vm-statsホットパス特定後、Fast-path/キャッシュ適用
🐛 既知の問題(要フォロー)
- 関数スタイル
isType(value, "Integer")が一部ケースでTypeOpにloweringされず、print %Xが未定義参照になる事象- 現状:
asTypeはtypeop castに変換されるが、isTypeが欠落するケースあり - 仮対処: Interpreterに
is/isType/as/asTypeのフォールバックを実装済(実行エラー回避) - 恒久対処(次回対応):
- Builderの早期loweringをFunctionCall分岐で強化(
Literal/StringBox両対応、print(...)内でも確実にdst生成) - Optimizerの安全ネット(BoxCall/Call→TypeOp)を
isTypeパターンでも確実に発火させる(テーブル駆動の判定)
- Builderの早期loweringをFunctionCall分岐で強化(
- 現状:
⏸️ セッション再開メモ(次にやること)
- Builder:
extract_string_literalのStringBox対応は導入済 →FunctionCall早期loweringの再検証(print(isType(...))直下) - Optimizer:
Call形式(関数呼び出し)でもisType/asTypeを検出してTypeOp(Check/Cast)に置換する安全ネットの強化とテスト - MIRダンプの確認:
local_tests/typeop_is_as_func_poc.nyashにtypeop check/castが両方出ることを確認 - スナップショット化:
typeop_is_as_*_poc.nyashのダンプを固定し回帰検出
▶ 補助コマンド(検証系)
# リビルド
cargo build --release -j32
# 関数スタイルのMIRダンプ確認(isType/asType)
./target/release/nyash --dump-mir --mir-verbose local_tests/typeop_is_as_func_poc.nyash | sed -n '1,200p'
# メソッドスタイルのMIRダンプ確認(is/as)
./target/release/nyash --dump-mir --mir-verbose local_tests/typeop_is_as_poc.nyash | sed -n '1,200p'
🆕 開発時の可視化・診断(最小追加)
--mir-verbose-effects: MIRダンプ行末に効果カテゴリを表示(pure|readonly|side)- 例:
nyash --dump-mir --mir-verbose --mir-verbose-effects local_tests/typeop_is_as_func_poc.nyash
- 例:
NYASH_OPT_DIAG_FAIL=1: Optimizer診断で未lowering(is|isType|as|asType)検知時にエラー終了(CI向け)- 例:
NYASH_OPT_DIAG_FAIL=1 nyash --dump-mir --mir-verbose local_tests/typeop_diag_fail.nyash
- 例:
- Builder生MIRスナップショット:
tools/snapshot_mir.sh <input.nyash> [output.txt]- 例:
tools/snapshot_mir.sh local_tests/typeop_is_as_func_poc.nyash docs/status/golden/typeop_is_as_func_poc.mir.txt
- 例:
- ゴールデン比較(ローカル/CI):
tools/ci_check_golden.sh(代表2ケースを比較)- 例:
./tools/ci_check_golden.sh(差分があれば非ゼロ終了)
- 例:
補足: ASTの形状確認は --dump-ast を使用。
▶ 実行コマンド例
計測実行:
tools/run_vm_stats.sh local_tests/vm_stats_http_ok.nyash vm_stats_ok.json
tools/run_vm_stats.sh local_tests/vm_stats_http_err.nyash vm_stats_err.json
tools/run_vm_stats.sh local_tests/vm_stats_http_404.nyash vm_stats_404.json
tools/run_vm_stats.sh local_tests/vm_stats_http_500.nyash vm_stats_500.json
VM×プラグインE2E:
cargo test -q --features plugins e2e_interpreter_plugin_filebox_close_void
cargo test -q --features plugins e2e_vm_plugin_filebox_close_void
MIR26 PoC(弱参照・Barrier統合):
# 弱フィールドPoC(flag OFF: WeakNew/WeakLoad/BarrierRead/Write)
NYASH_VM_STATS=1 NYASH_VM_STATS_JSON=1 ./target/release/nyash --backend vm --vm-stats --vm-stats-json local_tests/weak_field_poc.nyash > vm_stats_weak_default.json
# flag ON: WeakRef/Barrier 統合
cargo build --release --features mir_refbarrier_unify_poc -q
NYASH_VM_STATS=1 NYASH_VM_STATS_JSON=1 ./target/release/nyash --backend vm --vm-stats --vm-stats-json local_tests/weak_field_poc.nyash > vm_stats_weak_unified.json
MIRダンプ(プリンタ拡張後の確認):
./target/release/nyash --dump-mir --mir-verbose local_tests/weak_field_poc.nyash | sed -n '1,200p'
MIRダンプ/検証:
nyash --dump-mir --mir-verbose examples/plugin_box_sample.nyash
nyash --verify examples/plugin_box_sample.nyash
🔭 26命令ターゲット(合意ドラフト)
- コア: Const / Copy / Load / Store / BinOp / UnaryOp / Compare / Jump / Branch / Phi / Return / Call / BoxCall / NewBox / ArrayGet / ArraySet / RefNew / RefGet / RefSet / Await / Print / ExternCall(最小) / TypeOp(=TypeCheck/Cast統合) / WeakRef(=WeakNew/WeakLoad統合) / Barrier(=Read/Write統合)
- メタ降格: Debug / Nop / Safepoint(ビルドモードで制御)
最終更新: 2025年8月23日(VM強化・E2E拡張・me参照安定化・TypeOp/WeakRef/Barrier PoC完了/次段はプリンタ拡張・スナップショット・is/as導線)
🔁 再起動後の再開手順(ショート)
# 1) ビルド
cargo build --release -j32
# 2) plugins E2E(Linux)
cargo test --features plugins -q -- --nocapture
# 3) VM Stats 代表値の再取得(任意)
tools/run_vm_stats.sh local_tests/vm_stats_http_ok.nyash vm_stats_ok.json
tools/run_vm_stats.sh local_tests/vm_stats_http_err.nyash vm_stats_err.json
# 4) SocketBox タイムアウト確認(任意)
./target/release/nyash local_tests/socket_timeout_server.nyash
./target/release/nyash local_tests/socket_timeout_client.nyash
# 5) 反復タイムアウト確認(任意)
./target/release/nyash local_tests/socket_repeated_timeouts.nyash
# 6) HTTP 大ボディ確認(任意)
./target/release/nyash local_tests/http_big_body_client.nyash
# 7) VM BoxCall デバッグ(任意)
NYASH_VM_DEBUG_BOXCALL=1 ./target/release/nyash --backend vm local_tests/test_vm_array_getset.nyash