Files
hakorune/CURRENT_TASK.md
nyash-codex 02c689216b feat(joinir): Phase 216 Selfhost if-sum production test validation
Completes Phase 216: Validates Pattern 3 if-sum implementation with
actual selfhost test case from apps/tests/phase212_if_sum_min.hako.

## Test Results (All Passing)

### Primary Target
- phase212_if_sum_min.hako: RC=2 
  - Loop: i=0..2, sum increments when i>0
  - Expected: sum=2 (at i=1 and i=2)
  - Actual: RC=2

### Regression Tests
- loop_if_phi.hako (Pattern 3): RC=2 
- loop_min_while.hako (Pattern 1): RC=2 
- joinir_min_loop.hako (Pattern 2): RC=2 

## Validation

Confirmed Phase 215-2 fixes are production-ready:
1. JoinIR lowerer creates expr_result correctly
2. Boundary builder passes expr_result to pipeline
3. Final return uses merge result (not Void)
4. ExprResult contract matches Pattern 2

## Architecture

Pattern 3 if-sum flow:
- Source code → Parser → AST → Pattern3IfPhi detection
- JoinIR lowerer (AST extraction + expr_result creation)
- JoinInlineBoundary with expr_result
- JoinIRConversionPipeline returns merge result
- Pattern dispatcher returns expr_result (not Void)
- Final MIR function uses actual sum value
- VM execution: RC=2 (correct value, not 0)

## Documentation

- Added: docs/development/current/main/phase216-selfhost-if-sum-production.md
- Updated: CURRENT_TASK.md (Phase 213-216 complete status)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
2025-12-10 01:45:15 +09:00

6.7 KiB
Raw Blame History

Current Task

このファイルは「いま何に集中しているか」と「次にやり得る候補」だけを書く軽量ビューだよ。
詳細ログや過去フェーズの記録は docs/development/current/main/ 以下の各 phase-*.md
joinir-architecture-overview.md を真実のソースとして扱うことにするね。


🎯 今フォーカスしているテーマ2025-12-09 時点のスナップショット)

1. JoinIR ループ基盤の状態

  • LoopBuilder は完全削除済みで、ループは JoinIR Pattern14while / break / ifPHI / continue P5(Trim系) で統一。
  • JoinValueSpace / LoopHeaderPhi / ExitLine / JoinInlineBoundary / JoinIRVerifier まで含めた 「Loop → JoinIR → MIR → return」のパイプラインは、代表パターンと JsonParser ミニケースで安定している。
  • Phase 213216 完了: P3(ifPHI) は ifsum 最小パターン(phase212_if_sum_min.hako)まで AST ベースで一般化済みで、 Phase 215 で ExprResult の出口契約を Pattern2 と同じ形に揃えて RC=2 まで通すようになった。 Phase 216 で selfhost 側の production test も検証完了。

2. JsonParser / Trim / selfhost への適用状況

  • Trim 系:
    • _trim / _skip_whitespace の P5 パイプラインLoopBodyLocal 昇格 → bool carrier → TrimLoopLowerer
      JoinIR→MIR まで endtoend で安定動作。
  • JsonParser:
    • 11 ループ中、基本形P1/P2/P5 相当)の 7 本は JoinIR インフラ上で理論的にカバー可能と確認済み。
    • すでに JoinIR で実戦投入できているのは _skip_whitespace / _trim* / _match_literal / _atoi_min / _parse_number_min
    • 残りの複雑ループ(_parse_array / _parse_object / _unescape_string / 本体 _parse_string など)は
      「LoopBodyLocal + 複数 MethodCall + 複数フラグ」という組み合わせで、今後の拡張対象として整理済み。
  • selfhost (.hako):
    • selfhost stage3 depth1Rust→.hakoまでは JoinIR 経路で代表ケースが緑。
    • depth2.hako 側で JSON/MIR を読み、JoinIR/MIR/VM/LLVM に流すラインは、JsonParser 側のループカバレッジ拡張が前提。

3. 直近で意識しておきたい設計の芯

  • Loop パターン空間は有限で整理済み:
    • P1: Simple While
    • P2: Break
    • P3: IfPHI単一/複数キャリア)
    • P4: Continuethen/elsecontinue 正規化込み)
    • P5: LoopBodyLocal 昇格Trim/JsonParser 用の部分適用)
  • 「増やすべき」は新しい Pattern ではなく、既存 Pattern の前処理箱:
    • BoolExprLowerer / ConditionEnv / LoopConditionScopeBox / LoopBodyCarrierPromoter / TrimLoopHelper / ComplexAddendNormalizer / LoopBodyLocalEnv / UpdateEnv などで
      条件式とキャリア更新を吸収し、Pattern14 は「ループ骨格」に専念させる方針。
  • FailFast 原則:
    • JoinIR 以外のループ lowering パスは存在しないLoopBuilder は削除済み)。
    • 「わからないパターン」は必ず [joinir/freeze] 系の明示エラーにして、サイレントフォールバックはしない。

最近まとまった大きな塊(超要約)

ここ半年くらいで終わっている主な塊だけをざっくり書くね。
細かいタスク・バグ票・議論は phase-XXX*.md に全部残っているので、必要になったときだけそちらを読む想定。

  • LoopBuilder 削除ラインPhase 180 前後)
    • LoopBuilder を devonly → hard freeze → 物理削除まで完了。
    • Loop lowering の SSOT を JoinIR に一本化。
  • LoopPattern / Router ラインPhase 170179
    • LoopFeatures / LoopPatternKind / PatternRouter / PatternPipelineContext を整備。
    • Pattern14 の検出・ルーティングを「構造ベースAST features」で統一関数名ベタ書き依存を除去
  • Exit / Boundary / ValueId ラインPhase 172205
    • ExitMeta / ExitLineReconnector / JoinInlineBoundary(+Builder) / LoopHeaderPhiBuilder を箱化。
    • JoinValueSpaceParam/Local 領域)+ PHI 契約 Verifier で ValueId 衝突と PHI 破損を根治。
  • P5(Trim/JsonParser) ラインPhase 171176, 173175, 190193
    • LoopBodyLocal 昇格パイプラインTrim, _skip_whitespace, _parse_string 簡易版)を構築。
    • StringAppend / NumberAccumulation / Complex addend 正規化など、更新式まわりの箱を揃えた。
  • P3 (IfPHI) 汎用化ラインPhase 195196, 212215
    • multicarrier P3 の JoinIR 生成を整理。
    • Select 展開 / JoinIR→MIR ブリッジ側のバグPHI inputs, backedge, 二重 remapを修正。
    • ifsum 最小パターンを AST ベースで一般化し、ExprResult Exit 契約まで Pattern2 と揃えた。

このあたりが「JoinIR ループ基盤の芯」で、以降の Phase は JsonParser/selfhost の各ループへの適用フェーズ、という位置づけだよ。


🧭 これからの候補(まだ「やる」とは決めていないメモ)

ここは「やることリスト」ではなく「今後やるとしたらこの辺」というメモにする。
実際に着手するタイミングで、別途 Phase/タスクを切る想定だよ。

  1. JsonParser 残りループへの JoinIR 展開
    • _parse_array / _parse_object / _unescape_string / 本体 _parse_string など。
    • 既存の P2/P3/P4P5 パイプラインをどこまで延ばせるかを検証するフェーズ。
  2. selfhost depth2 ラインの再開
    • .hako 側で Program/MIR JSON を読んで JoinIR/MIR/VM/LLVM に流すライン。
    • JsonParser 側のカバレッジが上がったあとに、小さいループから順に移植する。
  3. JoinIR Verify / 最適化まわり
    • すでに PHI/ValueId 契約は debug ビルドで検証しているので、 必要なら SSADFA や軽い最適化Loop invariant / Strength reductionを検討。

📎 このファイルの運用ルール(自分向けメモ)

  • 過去フェーズの詳細な ToDo/Done リストは CURRENT_TASK には書かない
    代わりに phase-XXX*.mdjoinir-architecture-overview.md を SSOT として維持する。
  • CURRENT_TASK は「あくまで最新のフォーカスと次の候補だけ」に絞る。
    目安として このファイル自体は 2〜3画面程度〜300行以内 に収める。
  • 新しい大フェーズを始めたら:
    1. まず docs 配下に phase-XXX-*.md を書く。
    2. CURRENT_TASK には「そのフェーズの一行要約」と「今のフォーカスかどうか」だけを書く。