🎨 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:
67
test_p2p_debug.nyash
Normal file
67
test_p2p_debug.nyash
Normal file
@ -0,0 +1,67 @@
|
||||
// P2Pテスト - デバッグ版
|
||||
|
||||
print("=== P2P Debug Test ===")
|
||||
|
||||
// IntentBox
|
||||
box IntentBox {
|
||||
init { handlers }
|
||||
|
||||
setup() {
|
||||
print("IntentBox.setup() ENTER")
|
||||
me.handlers = new MapBox()
|
||||
print("IntentBox.setup() EXIT")
|
||||
}
|
||||
|
||||
deliver(messageType, data, from) {
|
||||
print("IntentBox.deliver() ENTER - args: " + messageType + ", " + data + ", " + from)
|
||||
print("Message: " + from + " -> " + messageType + " = " + data)
|
||||
print("IntentBox.deliver() EXIT")
|
||||
}
|
||||
}
|
||||
|
||||
// P2PBox
|
||||
box P2PBox {
|
||||
init { nodeId, intentBox }
|
||||
|
||||
setup(nodeId, intentBox) {
|
||||
print("P2PBox.setup() ENTER - nodeId: " + nodeId)
|
||||
me.nodeId = nodeId
|
||||
me.intentBox = intentBox
|
||||
print("P2PBox.setup() EXIT for " + nodeId)
|
||||
}
|
||||
|
||||
send(messageType, data) {
|
||||
print("P2PBox.send() ENTER - node: " + me.nodeId + ", type: " + messageType + ", data: " + data)
|
||||
print("About to call intentBox.deliver...")
|
||||
me.intentBox.deliver(messageType, data, me.nodeId)
|
||||
print("P2PBox.send() EXIT")
|
||||
}
|
||||
}
|
||||
|
||||
// テスト開始
|
||||
print("Creating IntentBox...")
|
||||
local bus
|
||||
bus = new IntentBox()
|
||||
print("Calling bus.setup()...")
|
||||
bus.setup()
|
||||
print("IntentBox ready!")
|
||||
|
||||
print("Creating Alice...")
|
||||
local alice
|
||||
alice = new P2PBox()
|
||||
print("Calling alice.setup()...")
|
||||
alice.setup("Alice", bus)
|
||||
print("Alice ready!")
|
||||
|
||||
print("Creating Bob...")
|
||||
local bob
|
||||
bob = new P2PBox()
|
||||
print("Calling bob.setup()...")
|
||||
bob.setup("Bob", bus)
|
||||
print("Bob ready!")
|
||||
|
||||
print("Alice sending message...")
|
||||
alice.send("hello", "Hi there!")
|
||||
print("Alice message sent!")
|
||||
|
||||
print("Test completed!")
|
||||
Reference in New Issue
Block a user