Files
hakorune/test_unused_field.nyash
Moe Charm e7f6666917 🎨 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>
2025-08-10 07:54:03 +09:00

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!")