## 🚀 主要機能追加 ### 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>
79 lines
1.8 KiB
Plaintext
79 lines
1.8 KiB
Plaintext
// 未使用フィールドテスト
|
|
|
|
print("=== Unused Field Test ===")
|
|
|
|
// Test 1: 未使用フィールドなし
|
|
box CleanTargetBox {
|
|
init { name }
|
|
|
|
deliver(a, b, c) {
|
|
print("CleanTargetBox.deliver: " + a + ", " + b + ", " + c)
|
|
}
|
|
}
|
|
|
|
box CleanCallerBox {
|
|
init { target, nodeId }
|
|
|
|
setup(targetRef) {
|
|
me.target = targetRef
|
|
me.nodeId = "TestValue"
|
|
print("CleanCallerBox setup completed")
|
|
}
|
|
|
|
test() {
|
|
print("Clean test: No unused fields...")
|
|
me.target.deliver("hello", "data", me.nodeId)
|
|
print("Clean test completed")
|
|
}
|
|
}
|
|
|
|
// Test 2: 未使用フィールドあり(元のハングパターン)
|
|
box DirtyTargetBox {
|
|
init { handlers } // 未使用フィールド!
|
|
|
|
deliver(a, b, c) {
|
|
print("DirtyTargetBox.deliver: " + a + ", " + b + ", " + c)
|
|
}
|
|
}
|
|
|
|
box DirtyCallerBox {
|
|
init { target, nodeId, unusedField } // 一部未使用
|
|
|
|
setup(targetRef) {
|
|
me.target = targetRef
|
|
me.nodeId = "TestValue"
|
|
// me.unusedField は設定しない
|
|
print("DirtyCallerBox setup completed")
|
|
}
|
|
|
|
test() {
|
|
print("Dirty test: With unused fields...")
|
|
me.target.deliver("hello", "data", me.nodeId)
|
|
print("Dirty test completed")
|
|
}
|
|
}
|
|
|
|
// テスト実行
|
|
print("Testing clean boxes (no unused fields)...")
|
|
local cleanTarget
|
|
cleanTarget = new CleanTargetBox()
|
|
|
|
local cleanCaller
|
|
cleanCaller = new CleanCallerBox()
|
|
cleanCaller.setup(cleanTarget)
|
|
cleanCaller.test()
|
|
|
|
print("Clean boxes worked!")
|
|
|
|
print("Testing dirty boxes (with unused fields)...")
|
|
local dirtyTarget
|
|
dirtyTarget = new DirtyTargetBox()
|
|
|
|
local dirtyCaller
|
|
dirtyCaller = new DirtyCallerBox()
|
|
dirtyCaller.setup(dirtyTarget)
|
|
dirtyCaller.test()
|
|
|
|
print("If you see this, unused fields also worked!")
|
|
|
|
print("All unused field tests completed!") |