Step 2完了: peek→match完全統一 + 重大PHI命令バグ発見
## 🎉 Step 2: peek→match完全統一アーキテクチャクリーンアップ完了 - ✅ 15ファイルで PeekExpr → MatchExpr 一括置換完了 - ✅ lowering/peek.rs → match_expr.rs 完全移行 - ✅ AI理解性・コードベース一貫性・保守性大幅向上 ## 🔍 Step 3: 複数行パース問題調査完了 - ✅ Task先生による根本原因特定完了 - 原因: オブジェクトリテラルパーサーの改行スキップ不足 - 修正: src/parser/expr/primary.rs の skip_newlines() 追加 ## 🚨 重大発見: PHI命令処理バグ - 問題: gemini_test_case.nyash で期待値2→実際0 - 原因: フェーズM+M.2のPHI統一作業でループ後変数マージに回帰バグ - 詳細: PHI命令は正常だが、print時に間違ったPHI参照 - 影響: Phase 15セルフホスティング基盤の重大バグ ## 📝 CLAUDE.md更新 - 全進捗状況の詳細記録 - 次のアクション: ChatGPT相談でMIRビルダー修正戦略立案 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
@ -154,7 +154,7 @@ impl NyashParser {
|
||||
};
|
||||
|
||||
// Wrap with peek: peek expr { null => null, else => access(expr) }
|
||||
expr = ASTNode::PeekExpr {
|
||||
expr = ASTNode::MatchExpr {
|
||||
scrutinee: Box::new(expr.clone()),
|
||||
arms: vec![(
|
||||
crate::ast::LiteralValue::Null,
|
||||
|
||||
@ -23,7 +23,7 @@ impl NyashParser {
|
||||
self.advance();
|
||||
let rhs = self.expr_parse_or()?;
|
||||
let scr = expr;
|
||||
expr = ASTNode::PeekExpr {
|
||||
expr = ASTNode::MatchExpr {
|
||||
scrutinee: Box::new(scr.clone()),
|
||||
arms: vec![(crate::ast::LiteralValue::Null, rhs)],
|
||||
else_expr: Box::new(scr),
|
||||
|
||||
@ -193,7 +193,7 @@ impl NyashParser {
|
||||
})?;
|
||||
|
||||
if !saw_type_arm && !saw_guard {
|
||||
// 既存の Lower を活用するため PeekExpr に落とす(型パターンが無い場合のみ)
|
||||
// 既存の Lower を活用するため MatchExpr に落とす(型パターンが無い場合のみ)
|
||||
let mut lit_arms: Vec<(LiteralValue, ASTNode)> = Vec::new();
|
||||
for arm in arms_any.into_iter() {
|
||||
match arm {
|
||||
@ -206,7 +206,7 @@ impl NyashParser {
|
||||
MatchArm::Type { .. } => unreachable!(),
|
||||
}
|
||||
}
|
||||
return Ok(ASTNode::PeekExpr {
|
||||
return Ok(ASTNode::MatchExpr {
|
||||
scrutinee: Box::new(scrutinee),
|
||||
arms: lit_arms,
|
||||
else_expr: Box::new(else_expr),
|
||||
|
||||
@ -46,7 +46,9 @@ impl NyashParser {
|
||||
let ident_key_on = std::env::var("NYASH_ENABLE_MAP_IDENT_KEY").ok().as_deref()
|
||||
== Some("1")
|
||||
|| sugar_level.as_deref() == Some("full");
|
||||
self.skip_newlines();
|
||||
while !self.match_token(&TokenType::RBRACE) && !self.is_at_end() {
|
||||
self.skip_newlines();
|
||||
let key = match &self.current_token().token_type {
|
||||
TokenType::STRING(s) => {
|
||||
let v = s.clone();
|
||||
@ -76,8 +78,10 @@ impl NyashParser {
|
||||
entries.push((key, value_expr));
|
||||
if self.match_token(&TokenType::COMMA) {
|
||||
self.advance();
|
||||
self.skip_newlines();
|
||||
}
|
||||
}
|
||||
self.skip_newlines();
|
||||
self.consume(TokenType::RBRACE)?;
|
||||
Ok(ASTNode::MapLiteral {
|
||||
entries,
|
||||
|
||||
Reference in New Issue
Block a user