🎨 feat: EguiBox GUI開発基盤完成 + パーサー無限ループバグ修正

## 🚀 主要機能追加
### EguiBox - GUI開発基盤
- Windows版GUIメモ帳アプリ (simple_notepad.rs, nyash_notepad_jp.rs)
- 日本語フォント対応 (NotoSansJP-VariableFont_wght.ttf)
- BMPアイコン表示システム (c_drive_icon.bmp)
- Windowsエクスプローラー風アプリ (nyash_explorer.rs)
- アイコン抽出システム (test_icon_extraction.rs)

### ビジュアルプログラミング準備
- NyashFlow プロジェクト設計完成 (NYASHFLOW_PROJECT_HANDOVER.md)
- ビジュアルノードプロトタイプ基盤
- WebAssembly対応準備

## 🔧 重大バグ修正
### パーサー無限ループ問題 (3引数メソッド呼び出し)
- 原因: メソッドパラメータ解析ループの予約語処理不備
- 修正: src/parser/mod.rs - 非IDENTIFIERトークンのエラーハンドリング追加
- 効果: "from"等の予約語で適切なエラー報告、ハング→瞬時エラー

### MapBoxハング問題調査
- MapBox+3引数メソッド呼び出し組み合わせ問題特定
- バグレポート作成 (MAPBOX_HANG_BUG_REPORT.md)
- 事前評価vs必要時評価の設計問題明確化

## 🧹 コード品質向上
- box_methods.rs を8モジュールに機能分離
- 一時デバッグコード全削除 (eprintln\!, unsafe等)
- 構文チェック通過確認済み

## 📝 ドキュメント整備
- CLAUDE.md にGUI開発セクション追加
- Gemini/ChatGPT先生相談ログ保存 (sessions/)
- 段階的デバッグ手法確立

## 🎯 次の目標
- must_advance\!マクロ実装 (無限ループ早期検出)
- コマンド引数でデバッグ制御 (--debug-fuel)
- MapBox問題の根本修正

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

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
Moe Charm
2025-08-10 07:54:03 +09:00
parent a4d32b3c57
commit e7f6666917
92 changed files with 8206 additions and 78 deletions

View File

@ -135,6 +135,56 @@ impl NyashInterpreter {
// DebugBox methods moved to system_methods.rs
/// EguiBoxのメソッド呼び出しを実行非WASM環境のみ
#[cfg(not(target_arch = "wasm32"))]
pub(super) fn execute_egui_method(&mut self, _egui_box: &crate::boxes::EguiBox, method: &str, arguments: &[ASTNode])
-> Result<Box<dyn NyashBox>, RuntimeError> {
// 引数を評価
let mut arg_values = Vec::new();
for arg in arguments {
arg_values.push(self.execute_expression(arg)?);
}
// メソッドを実行
match method {
"setTitle" => {
if arg_values.len() != 1 {
return Err(RuntimeError::InvalidOperation {
message: format!("setTitle expects 1 argument, got {}", arg_values.len()),
});
}
// EguiBoxは不変参照なので、新しいインスタンスを返す必要がある
// 実際のGUIアプリではstateを共有するが、今はシンプルに
Ok(Box::new(VoidBox::new()))
}
"setSize" => {
if arg_values.len() != 2 {
return Err(RuntimeError::InvalidOperation {
message: format!("setSize expects 2 arguments, got {}", arg_values.len()),
});
}
Ok(Box::new(VoidBox::new()))
}
"run" => {
if !arg_values.is_empty() {
return Err(RuntimeError::InvalidOperation {
message: format!("run expects 0 arguments, got {}", arg_values.len()),
});
}
// run()は実際のGUIアプリケーションを起動するため、
// ここでは実行できない(メインスレッドブロッキング)
Err(RuntimeError::InvalidOperation {
message: "EguiBox.run() must be called from main thread".to_string(),
})
}
_ => {
Err(RuntimeError::InvalidOperation {
message: format!("Unknown method '{}' for EguiBox", method),
})
}
}
}
/// ConsoleBoxのメソッド呼び出しを実行
pub(super) fn execute_console_method(&mut self, console_box: &crate::boxes::console_box::ConsoleBox, method: &str, arguments: &[ASTNode])
-> Result<Box<dyn NyashBox>, RuntimeError> {