## 🎉 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>
36 lines
1.2 KiB
Rust
36 lines
1.2 KiB
Rust
use crate::ast::{ASTNode, Span};
|
|
use crate::parser::common::ParserUtils;
|
|
use crate::parser::{NyashParser, ParseError};
|
|
use crate::tokenizer::TokenType;
|
|
|
|
#[inline]
|
|
fn is_sugar_enabled() -> bool {
|
|
crate::parser::sugar_gate::is_enabled()
|
|
}
|
|
|
|
impl NyashParser {
|
|
pub(crate) fn expr_parse_coalesce(&mut self) -> Result<ASTNode, ParseError> {
|
|
let mut expr = self.expr_parse_or()?;
|
|
while self.match_token(&TokenType::QmarkQmark) {
|
|
if !is_sugar_enabled() {
|
|
let line = self.current_token().line;
|
|
return Err(ParseError::UnexpectedToken {
|
|
found: self.current_token().token_type.clone(),
|
|
expected: "enable NYASH_SYNTAX_SUGAR_LEVEL=basic|full for '??'".to_string(),
|
|
line,
|
|
});
|
|
}
|
|
self.advance();
|
|
let rhs = self.expr_parse_or()?;
|
|
let scr = expr;
|
|
expr = ASTNode::MatchExpr {
|
|
scrutinee: Box::new(scr.clone()),
|
|
arms: vec![(crate::ast::LiteralValue::Null, rhs)],
|
|
else_expr: Box::new(scr),
|
|
span: Span::unknown(),
|
|
};
|
|
}
|
|
Ok(expr)
|
|
}
|
|
}
|