feat: match式オブジェクトリテラル判定修正完了 (peek→match統一 Step 1)

 Step 1完全達成:
- is_object_literal()メソッド追加でmatch式内オブジェクトリテラル対応
- match_token()副作用問題をcurrent_token()で解決
- 3箇所修正: デフォルト・型パターン・リテラルアーム全対応

🧪 動作確認済み:
- 基本match式:  回帰なし
- オブジェクトリテラル単体:  正常動作
- 単行match+オブジェクト:  完全動作

🚀 次段階準備:
- 複数行パース問題発見(後回し決定)
- peek→match完全統一 Step 2開始準備完了
- アーキテクチャクリーンアップによるソースコード美化へ

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

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
Selfhosting Dev
2025-09-23 08:18:23 +09:00
parent 09149be41a
commit f469b80f0a
2 changed files with 71 additions and 40 deletions

View File

@ -276,16 +276,18 @@ NYASH_DISABLE_PLUGINS=1 ./target/release/nyash program.nyash
NYASH_LLVM_USE_HARNESS=1 ./target/release/nyash program.nyash NYASH_LLVM_USE_HARNESS=1 ./target/release/nyash program.nyash
``` ```
## 📝 Update (2025-09-23) 🚀 フェーズM+M.2完全達成PHI統一革命完了 ## 📝 Update (2025-09-23) ✅ Step 1完了peek→match統一 Step 2開始
-**フェーズM.2完全達成!** JSON v0 Bridge層クリーンアップ完了でPHI完全統一実現 -**フェーズM+M.2完全達成!** PHI統一革命でcollect_prints問題根本解決
-**8箇所のno_phi分岐完全削除** try_catch(3)、ternary(1)、peek(1)、loop_(2)、expr(1) -**Step 1完全達成** match式オブジェクトリテラル判定修正完了
- **strip_phi_functions()削除!** 40行の複雑なPHI→edge-copy後処理撤廃 - **修正完了**: `src/parser/expr/match_expr.rs``is_object_literal()` メソッド追加
- **config::env::mir_no_phi()大幅簡略化!** 40行→8行、phi-legacy依存完全除去 - **副作用修正**: `match_token()``current_token()` で副作用除去
- **未使用コード完全削除!** PHI_ON_GATED_WARNED static、mir_no_phiフィールド等 - **動作確認**: 単行match式 + オブジェクトリテラル ✅ 完全動作
- 🔧 **安定性完全確認!** cargo check成功、基本・複雑PHIテスト両方正常動作 - **発見**: 複数行パース未対応(後回し決定)
- 📊 **圧縮効果絶大!** フェーズM+M.2で推定500行超削減達成 - 🚀 **Step 2開始準備** peek→match完全統一でアーキテクチャクリーンアップ
- 🎯 **Phase 15準備完了**: MIR層PHI統一により80k→20k行圧縮の主要基盤完成 - **対象ファイル**: `json_v0_bridge/ast.rs`, `lowering/peek.rs``match_expr.rs`
- 🚀 **次段階**: collect_prints動作確認→JSON v0 Bridge最終統合→Phase 15完遂 - **統一効果**: AI理解向上・ドキュメント整合性・保守性向上・ソースコード美化
- **作業順序**: claude.md更新→todo調整→commit→peek構造体→match構造体完全移行
- 🎯 **アーキテクチャ美化**: ややこしいpeek/match混在状況の完全解消へ
## 📝 Update (2025-09-22) 🎯 Phase 15 JITアーカイブ完了デバッグ大進展 ## 📝 Update (2025-09-22) 🎯 Phase 15 JITアーカイブ完了デバッグ大進展
-**JIT/Craneliftアーカイブ完了** Phase 15集中開発のため全JIT機能を安全にアーカイブ -**JIT/Craneliftアーカイブ完了** Phase 15集中開発のため全JIT機能を安全にアーカイブ

View File

@ -48,6 +48,10 @@ impl NyashParser {
} }
self.consume(TokenType::FatArrow)?; self.consume(TokenType::FatArrow)?;
let expr = if self.match_token(&TokenType::LBRACE) { let expr = if self.match_token(&TokenType::LBRACE) {
if self.is_object_literal() {
// オブジェクトリテラルとして処理
self.parse_expression()?
} else {
// ブロックを式として扱う(最後の文の値が返る) // ブロックを式として扱う(最後の文の値が返る)
self.advance(); // consume '{' self.advance(); // consume '{'
let mut stmts: Vec<ASTNode> = Vec::new(); let mut stmts: Vec<ASTNode> = Vec::new();
@ -62,6 +66,7 @@ impl NyashParser {
statements: stmts, statements: stmts,
span: Span::unknown(), span: Span::unknown(),
} }
}
} else { } else {
// 値アームは通常の式全体を受理 // 値アームは通常の式全体を受理
self.parse_expression()? self.parse_expression()?
@ -104,6 +109,10 @@ impl NyashParser {
} else { None }; } else { None };
self.consume(TokenType::FatArrow)?; self.consume(TokenType::FatArrow)?;
let body = if self.match_token(&TokenType::LBRACE) { let body = if self.match_token(&TokenType::LBRACE) {
if self.is_object_literal() {
// オブジェクトリテラルとして処理
self.parse_expression()?
} else {
self.advance(); // consume '{' self.advance(); // consume '{'
let mut stmts: Vec<ASTNode> = Vec::new(); let mut stmts: Vec<ASTNode> = Vec::new();
while !self.match_token(&TokenType::RBRACE) && !self.is_at_end() { while !self.match_token(&TokenType::RBRACE) && !self.is_at_end() {
@ -115,6 +124,7 @@ impl NyashParser {
} }
self.consume(TokenType::RBRACE)?; self.consume(TokenType::RBRACE)?;
ASTNode::Program { statements: stmts, span: Span::unknown() } ASTNode::Program { statements: stmts, span: Span::unknown() }
}
} else { } else {
// 値アームは通常の式全体を受理 // 値アームは通常の式全体を受理
self.parse_expression()? self.parse_expression()?
@ -144,6 +154,10 @@ impl NyashParser {
} else { None }; } else { None };
self.consume(TokenType::FatArrow)?; self.consume(TokenType::FatArrow)?;
let expr = if self.match_token(&TokenType::LBRACE) { let expr = if self.match_token(&TokenType::LBRACE) {
if self.is_object_literal() {
// オブジェクトリテラルとして処理
self.parse_expression()?
} else {
self.advance(); // consume '{' self.advance(); // consume '{'
let mut stmts: Vec<ASTNode> = Vec::new(); let mut stmts: Vec<ASTNode> = Vec::new();
while !self.match_token(&TokenType::RBRACE) && !self.is_at_end() { while !self.match_token(&TokenType::RBRACE) && !self.is_at_end() {
@ -155,6 +169,7 @@ impl NyashParser {
} }
self.consume(TokenType::RBRACE)?; self.consume(TokenType::RBRACE)?;
ASTNode::Program { statements: stmts, span: Span::unknown() } ASTNode::Program { statements: stmts, span: Span::unknown() }
}
} else { } else {
// 値アームは通常の式全体を受理 // 値アームは通常の式全体を受理
self.parse_expression()? self.parse_expression()?
@ -309,6 +324,20 @@ impl NyashParser {
}) })
} }
/// オブジェクトリテラル判定: { IDENTIFIER : または { STRING : の場合はtrue
fn is_object_literal(&self) -> bool {
// 副作用を避けるためcurrent_token()を使用
if !matches!(self.current_token().token_type, TokenType::LBRACE) {
return false;
}
match self.peek_token() {
TokenType::IDENTIFIER(_) | TokenType::STRING(_) => {
matches!(self.peek_nth_token(2), TokenType::COLON)
}
_ => false
}
}
// match 用の最小リテラルパーサ(式は受け付けない) // match 用の最小リテラルパーサ(式は受け付けない)
fn lit_only_for_match(&mut self) -> Result<crate::ast::LiteralValue, ParseError> { fn lit_only_for_match(&mut self) -> Result<crate::ast::LiteralValue, ParseError> {
match &self.current_token().token_type { match &self.current_token().token_type {