Commit Graph

42 Commits

Author SHA1 Message Date
fffbac9aac feat: MIR TypeOp/WeakRef/Barrier PoC implementation
- Add TypeOpKind, WeakRefOp, BarrierOp enums for unified instructions
- Implement TypeOp instruction combining TypeCheck/Cast
- Implement WeakRef instruction combining WeakNew/WeakLoad
- Implement Barrier instruction combining BarrierRead/BarrierWrite
- Update VM to handle new unified instructions
- Update MIR printer for new instruction formats
- Add feature flags mir_typeop_poc and mir_refbarrier_unify_poc
- Maintain backward compatibility with legacy instructions

This is Phase 8.5 MIR instruction diet PoC implementation.

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-23 19:27:02 +09:00
cc2a820af7 feat(plugin): Fix plugin BoxRef return and Box argument support
- Fixed deadlock in FileBox plugin copyFrom implementation (single lock)
- Added TLV Handle (tag=8) parsing in calls.rs for returned BoxRefs
- Improved plugin loader with config path consistency and detailed logging
- Fixed loader routing for proper Handle type_id/fini_method_id resolution
- Added detailed logging for TLV encoding/decoding in plugin_loader_v2

Test docs/examples/plugin_boxref_return.nyash now works correctly:
- cloneSelf() returns FileBox Handle properly
- copyFrom(Box) accepts plugin Box arguments
- Both FileBox instances close and fini correctly

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-21 00:41:26 +09:00
dce53bf683 feat(phase-9.78b): Complete plugin Box inheritance and argument support
ChatGPT5による大規模改善:
-  プラグインBox継承サポート完成
-  from Parent.method()でプラグインメソッド呼び出し
-  引数・戻り値のTLVエンコード/デコード
-  借用チェッカーエラー全解決
-  MIRビルダーのクローン修正

次期作業:
- Phase 9.78b Step 3: BoxFactory dyn化
- アーキテクチャ改善継続

Co-authored-by: ChatGPT5 <noreply@openai.com>
2025-08-20 20:56:08 +09:00
86b9f7719b 🏗️ feat: Phase 9.78b準備 - インタープリター・VM統合アーキテクチャ設計
Phase 9.78b: Codexの天才的分析に基づくアーキテクチャ再設計準備

## 📋 実施内容
1. Codex分析結果のアーカイブ
   - 実装詳細共有 → モデル共有・実行時共有への転換提案
   - 8ステップの段階的実装計画

2. Phase 9.78a作業の保存
   - MIR生成でのNewBox命令統一(保持)
   - ScopeTracker基本実装(一時コメントアウト)
   - VM拡張の方向性(TODOコメント付き)

3. ビルドエラー修正
   - ScopeTrackerインポート問題を一時的に解決
   - ビルド成功(警告のみ)

## 📚 作成ドキュメント
- architecture-redesign-proposal.md - Codexの設計提案
- phase_9_78b_interpreter_architecture_refactoring.md - 実装計画
- codex-analysis/* - 分析結果アーカイブ

## 🎯 次のステップ
Phase 9.78b Step 1: BoxDeclarationをcore::modelへ移動
2025-08-20 17:58:51 +09:00
c11b68af90 📝 docs: Phase 9.78a実装箇所詳細分析追加
## 🔍 実装箇所の詳細分析
- MIR生成部分: build_new_expression()でRefNew→NewBox修正
- VM実行部分: 主要な修正箇所(BoxFactory統合、スコープ管理)
- 共有コンポーネント: BoxFactory、InstanceBoxをVMでも使用

## 📋 CURRENT_TASK.md更新
- Phase 9.78a VM統一Box処理の実装ステップ詳細化
- Step 1-5の具体的な実装内容を明記
- 関連ドキュメントへのリンク追加

次はStep 1のMIR生成修正から実装開始!

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-20 16:08:22 +09:00
59cae9fe2a 📚 docs: VM Plugin System統合の完全設計
Phase 9.78a: VM統一Box処理アーキテクチャ

## 🎯 解決した問題
- ユーザー定義Box未対応 → BoxFactory統合で解決
- birth/finiライフサイクル欠落 → ScopeTracker実装で解決
- メソッド呼び出しハードコード → 統一ディスパッチで解決

## 📚 作成したドキュメント
- Phase 9.78a VM Plugin Integration計画書
- Phase 9.78a 深層分析(インタープリター比較)
- VM Plugin Integration仕様書(統一アーキテクチャ)

## 🌟 統一設計の核心
Everything is Box + 統一ライフサイクル
- すべてのBox型(ビルトイン/ユーザー定義/プラグイン)が同じ扱い
- birth → 使用 → fini の一貫性
- シンプルで保守しやすい実装

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-20 15:58:28 +09:00
c2af6c9987 docs: Add Phase 9.78 Unified BoxFactory Architecture design
- Add comprehensive design discussion with Gemini about unified BoxFactory
- Define Phase 9.78 implementation plan with 6 sub-phases (9.78a-f)
- Include clone_box/share_box semantics clarification and fixes
- Update CURRENT_TASK.md with specific misimplementation details
- Archive Gemini's deep technical analysis endorsing the approach

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-19 16:21:34 +09:00
012fc1930f feat: Extract BID converter from Copilot and prepare plugin migration
- Extract Copilot's BID converter code to src/bid-converter-copilot/ for future use
- Create comprehensive plugin migration request document for Copilot
- Target 13 built-in boxes for plugin conversion (HTTP, GUI, Audio, etc.)
- Preserve existing nyash.toml-based plugin system
- Reorganize docs/説明書/reference/ structure for better organization
2025-08-18 20:53:48 +09:00
f4988985a7 docs: Phase 9.78 LLVM PoC - AI大会議結果とCopilot実装ガイド作成
- AI大会議(Gemini/Codex)でLLVM実装戦略を策定
- inkwellクレート使用、Box型はptr型で表現、ランタイム委譲戦略
- Week 1: Hello World(return 42)の実装から開始
- 3週間で基本動作確認、目標10倍以上の性能向上
- Copilot用の詳細な実装ガイドとIssueテンプレート作成

Phase 8.6 VM性能改善(50.94倍高速化)完了を受けて、
次なる性能革命としてLLVMバックエンド実装を開始!

🚀 Ready to make Nyash fly with LLVM!
2025-08-18 17:51:31 +09:00
ea40437d4d docs: Update architecture documentation and add plugin-tester to CLAUDE.md
## Documentation Updates

### phase_9_75g_bid_integration_architecture.md
- Added detailed Phase 9.75g-0 implementation results
- Included FileBox plugin implementation details (293KB .so, 6 methods)
- Added plugin-tester diagnostic tool output examples
- Updated Phase 9.75g-1 implementation plan with concrete steps:
  - Step 4.1: TLV encode/decode (src/bid/tlv.rs)
  - Step 4.2: Plugin loader (plugin-tester migration)
  - Step 4.3: BoxFactoryRegistry (transparent switching)
  - Step 4.4: PluginBox proxy (NyashBox implementation)

### CLAUDE.md
- Added plugin-tester section to testing documentation
- Included build/run instructions and output examples
- Documented key features: Box name self-declaration, generic design
- Updated final timestamp to 2025-08-18 reflecting BID-FFI foundation completion

## Key Achievements Documented
-  Box name non-hardcoded design (plugins declare themselves)
-  Generic plugin-tester works with any plugin
-  birth/fini lifecycle management implementation
-  Memory ownership rules clarification

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-18 09:58:15 +09:00
72b63546b0 feat(phase-9.75g-0): Add simple nyash.toml parser for plugin configuration
-  Simple TOML parser for [plugins] section
-  Maps Box names to plugin names (e.g., FileBox => filebox)
-  Handles comments and empty lines
-  Complete test coverage
- 🎯 Minimal implementation for transparent Box replacement!

Part of Day 4 FileBox plugin implementation (60% → 70%)

🤖 Generated with Claude Code

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-17 22:05:47 +09:00
a5ff3ecafe feat(phase-9.75g-0): Implement BID-FFI Day 3 - Box type integration
- Implement BID Box Bridge interface for Nyash Box <-> BID Handle conversion
- Add StringBox BID bridge implementation with handle/TLV support
- Add IntegerBox BID bridge implementation with handle/TLV support
- Implement BoxRegistry for managing Box instances and handles
- Add comprehensive tests for StringBox/IntegerBox BID round-trip
- Extract helper functions for string/integer value extraction

Everything is Box philosophy shines through unified BID integration! 🎉

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-17 19:54:57 +09:00
2b738196ca feat(phase-9.75g-0): Adopt ChatGPT final BID-FFI design and update specifications
- Update ffi-abi-specification.md to BID-1 Enhanced Edition
  - Add efficient Handle design (type_id + instance_id)
  - Define BID-1 TLV unified format for arguments/results
  - Add Plugin API with NyashHostVtable and metadata support
  - Include complete FileBox plugin example in C
  - Standardize error codes (NYB_SUCCESS, NYB_E_*)
  - Support 8-byte alignment and platform-dependent usize

- Add phase_9_75g_0_chatgpt_enhanced_final.md as the final design
  - Incorporates all ChatGPT-5 recommendations
  - Confirms 1-week implementation feasibility
  - Aligns with Everything is Box philosophy

- Update CURRENT_TASK.md to reflect Day 1 progress
  - Mark specification finalization as complete
  - Ready to start actual implementation

Everything is Box philosophy meets practical FFI/ABI design\!

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-17 18:17:04 +09:00
75d09a89a8 feat(phase-9.75g-0): Start BID-FFI type-first implementation strategy
- Create comprehensive type definitions for all future features
- Adopt FFI ABI v0 compliance with platform-aware pointers (usize)
- Implement 8-byte alignment for cross-platform compatibility
- Design single entry point: nyash_plugin_invoke
- Target Linux x86-64 for initial implementation
- Use unimplemented!() for gradual feature addition

Key decisions from AI review:
- Pointer width: platform-dependent (not fixed 32-bit)
- Early addition of Option/Result types
- Clear ownership rules for strings/arrays
- Extensible BoxHeader with magic number

Phase 9.75g-0: Build it simple, make it work, then extend!
2025-08-17 17:31:46 +09:00
2a762d94a1 docs(phase-5.4): Update documentation for MIR 26-instruction project
Phase 5.4 of MIR 35→26 reduction project:
- Create MIR 26-instruction specification document
- Update CURRENT_TASK.md with Phase 5 progress
- Update phase_8_5_mir_35_to_26_reduction.md with completion status
- Document amazing progress: 90% completion in 1 day vs 5 weeks estimate

Documentation updates:
- docs/説明書/reference/mir-26-specification.md: Complete specification
- docs/CURRENT_TASK.md: Phase 5-4 in progress
- docs/予定/native-plan/issues/phase_8_5_mir_35_to_26_reduction.md: Status updates

Next: Update test files to remove deprecated instructions
2025-08-17 14:21:49 +09:00
3df87fb1ce fix(phase-4.3c-3): Fix StringBox literal handling in MIR builder
Phase 4-3c-3 Complete: WASM host functions now correctly output string content

## Changes:
- Fixed MIR builder to handle StringBox with string literal arguments
- Special case for  to generate proper string constants
- Removed debug output after successful verification
- WASM now correctly outputs "Hello MIR!" instead of "StringBox"

## Test Results:
- MIR generation:  Generates  correctly
- WASM compilation:  String data correctly placed at offset 4096
- WASM execution:  Outputs "Hello MIR\!" as expected

## Technical Details:
- Modified build_new_expression() to detect StringBox with literal arguments
- Generates Const instruction with actual string content
- Host function reads StringBox memory layout correctly

This completes the WASM string output functionality for Phase 4.

🤖 Generated with Claude Code
Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-17 13:49:35 +09:00
349dba24b5 docs: Add Phase 9.75f Option C implementation plans
- Phase 9.75f-1: FileBox dynamic library (immediate)
- Phase 9.75f-2: Math/Time boxes dynamic (this week)
- Phase 9.75f-3: Core types experiment (future)
- Update CURRENT_TASK.md with Option C strategy
- Refine todo list for phased implementation
2025-08-17 04:06:42 +09:00
d396c0ed8c feat(phase-9.75f): ビルトインBox動的ライブラリ分離アーキテクチャ設計
- Gemini先生のアドバイスに基づく実装計画策定
- C ABI + libloading による安定した動的ライブラリ実装
- 段階的移行戦略:インタープリターExternCall → プラグイン化
- FFI-ABI file実装(stdlib方式)完了
- MIRビルダーにfile.read/write/exists追加
- ビルド時間2分→15秒、バイナリ15MB→2MBを目標
- docs/予定/native-plan/issues/phase_9_75f_dynamic_library_architecture.md作成
- CURRENT_TASK.md更新

次のステップ:
- インタープリターでExternCall直接実行実装
- 元のFileBox実装を探して置き換え
- プラグインアーキテクチャ基盤構築
2025-08-17 03:40:00 +09:00
939af77a59 docs: Update copilot_issues.txt with interpreter hybrid strategy
Major changes:
- Remove completed phases: 9.5, 9.6, 9.7, 9.75
- Update Phase 9.77 status (UTF-8 error investigation, Issue #110)
- Add interpreter hybrid strategy (Python-like practicality)
- Update Phase 10 with async/await native implementation
- Emphasize interpreter value for both development and production

Key insights:
- Interpreter is practical for production use (like Python)
- Best of both worlds: interpreter convenience + compiler performance
- Hybrid approach: use interpreter for most tasks, AOT for performance-critical

🤖 Generated with Claude Code

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-16 21:47:14 +09:00
ef7a0de3b0 feat: Prepare for code modularization and cleanup
- Archive old documentation and test files to `docs/archive/` and `local_tests/`.
- Remove various temporary and old files from the project root.
- Add `nekocode-rust` analysis tool and its output files (`nekocode/`, `.nekocode_sessions/`, `analysis.json`).
- Minor updates to `apps/chip8_nyash/chip8_emulator.nyash` and `local_tests` files.

This commit cleans up the repository and sets the stage for further code modularization efforts, particularly in the `src/interpreter` and `src/parser` modules, based on recent analysis.
2025-08-16 01:30:39 +09:00
601b1f08e3 feat(design): implement birth() unified system design with transparency removal
## 🌟 birth() Unified System Design - Gemini Expert Approval
- Adopt explicit birth() method calls for all Box inheritance
- Complete removal of pack transparency system
- Maintain Nyash's explicit philosophy and predictability

## 🚨 Fix Documentation Inconsistencies
- Update CURRENT_TASK.md: birth() unified design decision
- Create phase_8_9_birth_unified_system_copilot_proof.md task specification
- Add Gemini consultation documentation for design validation

## 📋 New Explicit Syntax Design
```nyash
#  New explicit syntax (Gemini recommended)
box EnhancedString from StringBox {
    birth(content, prefixStr) {
        from StringBox.birth(content)  # ← Explicit method call\!
        me.prefix = prefixStr
    }
}
```

## 🔧 Implementation Requirements
- Parser modification: remove transparency support from `from Parent()`
- Interpreter modification: remove `execute_builtin_constructor_call()`
- Weak reference lifecycle fix: auto-nullification after fini()
- Comprehensive test cases with hand-off prevention metrics

## 🎯 Success Criteria (No Compromise)
- Complete transparency system eradication 
- Explicit birth() syntax enforcement 
- Weak reference lifecycle correction 
- All test cases complete PASS 
- Nyash explicit philosophy complete restoration 

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-15 20:31:14 +09:00
6b62209da9 feat(constructor): implement birth() syntax and pack transparency system
## 🌟 birth() Constructor Implementation
- Add BIRTH token to tokenizer (src/tokenizer.rs:37,403)
- Implement birth() parser support (src/parser/mod.rs)
- Add birth() interpreter support with priority system
- Priority: birth > pack > init > Box名

## 🚨 Fix Documentation Inconsistencies
- Fix delegation-system.md: pack → birth unified
- Fix box-design/README.md: add pack-specific section
- Fix LANGUAGE_GUIDE.md: birth unified, pack builtin-only
- Fix CLAUDE.md: birth philosophy, pack system separation

## 📋 pack Transparency System Design
- Create phase_8_8_pack_transparency_system.md specification
- Establish correct pack definition: builtin Box inheritance only
- Design user-transparent system: from BuiltinBox() → internal pack
- Comprehensive test cases and implementation requirements

## 🧪 Testing
- Add test_birth_simple.nyash: birth() functionality verification
- Document constructor name decision process
- Prepare for Copilot implementation with clear specifications

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-15 19:34:26 +09:00
de180d2bf5 📚 Add WASM documentation - Phase 9.77 planning and Rust dependency analysis
- Add docs/説明書/wasm/README.md: WASM comprehensive guide
- Add docs/説明書/wasm/rust-dependency-analysis.md: Detailed Rust dependency analysis
- Add docs/予定/native-plan/issues/phase_9_77_wasm_emergency.md: Emergency recovery plan
- Update copilot_issues.txt: Add Phase 9.77 between 9.75 and 9.8

Phase 9.77 strategy: Manual implementation → FFI foundation (Phase 9.8+)
Both approaches achieve zero Rust runtime dependency via WASM + JavaScript
2025-08-15 15:24:03 +09:00
f7f651d095 📋 Phase 10: Add Classic C Applications Migration Plan - Triple Porting Project
## Summary
Created comprehensive migration plan for 3 classic C applications to Nyash
- Issue #98: Triple porting project specification
- Advanced memory management features testing strategy

## Applications Selected

### 1. 🌐 Tinyproxy - Zero-copy Detection Testing
- **Target**: HTTP proxy server (~5000 lines C)
- **Focus**: Zero-copy optimization validation
- **APIs**: `is_shared_with()`, `share_reference()`
- **Goal**: 90%+ zero-copy rate in HTTP forwarding

### 2. 🎮 Chip-8 Emulator - fini Propagation & Weak References
- **Target**: 8-bit game machine emulator (~1000 lines C)
- **Focus**: Automatic cleanup chains, circular reference handling
- **APIs**: `fini()` propagation, `is_alive()` weak checking
- **Goal**: 60FPS stable emulation + complete fini propagation

### 3. ✏️ kilo Text Editor - "Accidental Full Copy" Detection
- **Target**: Lightweight terminal editor (~1000 lines C)
- **Focus**: Memory efficiency monitoring, copy detection
- **APIs**: `memory_footprint()`, real-time efficiency warnings
- **Goal**: 95%+ memory efficiency for 1MB+ file editing

## Technical Implementation Plan

### New API Requirements
- **Zero-copy APIs**: BufferBox sharing detection
- **fini propagation**: Automatic dependency cleanup
- **Weak references**: Circular reference prevention
- **Memory monitoring**: Real-time efficiency tracking

### Development Timeline
- **Phase 10.1**: Tinyproxy (1 week) - Zero-copy foundation
- **Phase 10.2**: Chip-8 (1 week) - Memory management testing
- **Phase 10.3**: kilo (1 week) - Efficiency monitoring
- **Phase 10.4**: Integration (1 week) - Performance analysis

## Strategic Value
1. **Practical proof**: Real applications can be built with Nyash
2. **Feature validation**: Advanced memory management in production
3. **Developer experience**: Copilot collaboration productivity
4. **Ecosystem expansion**: Concrete Nyash application examples

**Success of this migration establishes Nyash as a practical programming language\!** 🚀

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-15 14:48:28 +09:00
498224b530 🗂️ Phase 9.75D: Remove duplicate traits.rs file - complete trait consolidation
## Summary
- Removed unused duplicate file: src/boxes/traits.rs (88 lines)
- Kept main trait definition file: src/box_trait.rs (904 lines, 60+ files using it)
- Completed trait system consolidation

## Analysis Results
-  src/boxes/traits.rs: 88 lines, 0 files using it, missing share_box() method
-  src/box_trait.rs: 904 lines, 60+ files using it, complete trait implementation

## Changes Made
- Deleted: src/boxes/traits.rs (outdated, incomplete, unused)
- Preserved: src/box_trait.rs (current, complete, widely used)

## Verification
-  `cargo check` passes successfully (no errors, only warnings)
-  No build dependencies broken
-  All Box trait implementations remain functional
-  Unified trait system with single source of truth

## Result
- Single authoritative trait definition file
- Eliminated confusion from duplicate implementations
- Cleaner codebase architecture
- Ready for Phase 9.75D VM/WASM backend development

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-15 14:36:49 +09:00
22bcc4edd4 docs(phase-9.75d): add clone_box vs share_box redesign specification
Phase 9.75D設計ドキュメント・移行計画・Copilot Issue作成
- ArrayBox状態保持問題の根本解決策を設計
- Gemini AI相談結果を基にした責務分離アーキテクチャ
- 7日間5フェーズの段階的移行計画策定
- 20個のBox型修正手順をCopilot Issue化

🎯 Core Solution: clone_box() (値) vs share_box() (参照) 責務分離
🔧 Target: 15個ステートフルBoxの状態保持機能復活
📋 Ready: Copilot実装作業開始可能

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-15 13:15:26 +09:00
d0a1e43f9a docs(issues): DebugBox Arc<Mutex>→RwLock変換Issue作成 + FutureBox import修正
## 📋 新規Issue作成
- phase_9_75c_debugbox_fix.md: DebugBox専用修正Issue作成
- phase_9_75c_fix_compile_errors_jp.md: 既存Issue日本語版更新

## 🔧 FutureBox import修正
- src/interpreter/mod.rs: crate::boxes::FutureBox import追加
- src/interpreter/io.rs: FutureBox import パス修正

## 🎯 現状
- Issue #92:  解決済み (FutureBox二重定義)
- PR #93:  完了 (FutureBox統一)
- 残存: 39個エラー (DebugBox未変換)

## 📊 技術詳細
- DebugBox: 11箇所の.lock() → .read()/.write()変換必要
- Clone derive: 手動実装が必要
- 他10個Box型: RwLock変換完了済み

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-15 11:44:10 +09:00
b55cd60bfa docs(copilot): reorganize copilot_issues.txt - focus on Phase 9.5+
- Remove Phase 9.5前 content (already backed up)
- Merge duplicate Phase 10 sections into unified structure
- Focus on current development priorities (Phase 9.5+)
- Improve readability and eliminate redundancy

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-15 10:37:44 +09:00
4acc0459bb docs(copilot): add Phase 9.6 WASM independent implementation & split document
Phase 9.6: WASM独自実装 - wasmtime依存完全排除
- Add critical Phase 9.6 for wasmtime dependency elimination
- Pure WAT Generation approach for version compatibility issues
- BoxCall/ExternCall independent implementation
- Scheduled after Phase 9.5, before Phase 9.7
- 2-week implementation timeline with Copilot collaboration

Document split for maintainability:
- Split copilot_issues.txt (1200+ lines → ~600 lines)
- Archive Phase 0-9.4 to copilot_issues_phase0_to_94.txt
- Improve searchability and maintenance efficiency

WASM独自実装の革命的効果:
- wasmtime依存完全排除でバージョン互換性問題解決
- BoxCall/ExternCall完全実装で実用性達成
- Pure WAT Generation による軽量・高性能実現
- Everything is Box哲学の純粋実装

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-15 10:21:26 +09:00
3a0ac23ee6 docs(phase9.75): prepare Phase 9.75-C implementation for remaining 10 Box types
- Add phase9_75c_remaining_boxes_arc_mutex_final.md: comprehensive implementation guide for remaining Arc<Mutex> → RwLock conversions
- Restore phase9_75b_remaining_boxes_arc_mutex_redesign.md: recovered from git history
- Update CURRENT_TASK.md: reflect Phase 9.75-B partial completion and PR #87 SocketBox success

Phase 9.75-B Success Summary:
 SocketBox: PR #87 - state persistence issue completely resolved
 5 Box types: PR #89 - ArrayBox, MapBox, BufferBox, StreamBox, DebugBox converted to RwLock
 Build success: 0 compilation errors

Phase 9.75-C Ready:
🎯 10 remaining Box types identified with priority-based implementation plan
🔧 Proven conversion pattern established from PR #87 success
📋 2-week timeline with HTTPServerBox/P2PBox as highest priority

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-15 09:33:48 +09:00
e0f0a658e6 docs: Phase 9.75 Box設計根本革命 - SocketBox Arc<Mutex>責務一元化
 Phase 9.75実装計画追加:
- copilot_issues.txtにPhase 9.75追加(Phase 9.7と9.8の間)
- Arc<Mutex>二重化問題の根本解決計画
- 段階的実装戦略(Phase A-D)定義

📚 Box設計ドキュメント完全体系化:
- docs/説明書/reference/box-design/ 新設
- everything-is-box.md: 核心哲学の完全解説
- memory-management.md: Arc<Mutex>設計・fini/weak参照
- delegation-system.md: 完全明示デリゲーション仕様
- box-types-catalog.md: 全Box型の完全カタログ
- ffi-abi-specification.md: FFI/ABI仕様(移動済み)

🔧 実装ノート完備:
- current-issues.md: 現在進行中の設計課題
- socket-box-problem.md: Arc<Mutex>二重化問題詳細分析
- phase-9-75-redesign.md: 実装計画詳細

👥 Copilot実装ガイド作成:
- phase9_75_socketbox_arc_mutex_redesign.md
- SocketBox優先対応の具体的実装手順
- 完全テストスイート設計
- 段階的実装戦略(Step 1-5)

📋 CURRENT_TASK.md更新:
- Box設計ドキュメント完成記録
- Phase 9.75準備完了状況

🎯 効果:
- Everything is Box哲学の体系的文書化
- SocketBox問題解決の明確な道筋
- Copilot協調実装の準備完了
- 新規開発者オンボーディング改善

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-15 07:47:09 +09:00
80c911d3c8 🚨 Critical Issue #76: SocketBox Method Call Deadlock Investigation
## 🎯 Problem Identification Complete
- SocketBox method calls (bind, isServer, toString) cause infinite blocking
- Root cause: Method resolution pipeline deadlock before execute_socket_method
- Other Box types (ArrayBox, StringBox, MapBox) work normally
- Arc<Mutex> reference sharing confirmed working (Arc addresses match = true)

## 🔧 Debug Infrastructure Added
- Comprehensive debug logging in socket_box.rs (bind, isServer, clone, toString)
- Method call tracing in http_methods.rs
- Deadlock detection points identified at interpreter expressions.rs:462-464

## 📋 Issue #76 Created for Copilot Investigation
- Systematic root cause analysis requirements (Architecture→Parser→Runtime levels)
- Comprehensive test cases: minimal/comprehensive/comparison scenarios
- Strict prohibition of band-aid fixes - architectural analysis required
- Hypothesis: Multiple Arc<Mutex> combinations causing circular deadlock

## 🧪 Test Suite Added
- test_socket_deadlock_minimal.nyash: Minimal reproduction case
- test_socket_methods_comprehensive.nyash: All methods deadlock verification
- test_other_boxes_working.nyash: Normal Box operation confirmation
- SOCKETBOX_ISSUE_REPRODUCTION.md: Complete reproduction guide

## 📊 Impact Assessment
- Phase 9 HTTP server implementation completely blocked
- SocketBox functionality entirely non-functional
- Critical blocker for production readiness
- Requires immediate systematic investigation

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-14 20:55:33 +09:00
9b25330d94 docs: NyIR Core 26命令統一完了 - Universal Exchange Vision基盤確立
## 🌟 主要変更
- NyIR Core: 25命令 → 26命令(ExternCall追加)
- Universal Exchange Vision実現基盤完成
- Everything is Box哲学:外部ライブラリ統一対応

## 📋 完了した統一作業
-  docs/nyir/spec.md: 26命令正式仕様確定
-  docs/nyir/vision_universal_exchange.md: ChatGPT5ビジョン統合
-  docs/予定/native-plan/copilot_issues.txt: 実装計画全面更新
-  Extension戦略再定義: 言語固有機能に限定

## 🎯 26命令完全定義
**Tier-0 (8命令)**: Const, BinOp, Compare, Branch, Jump, Phi, Call, Return
**Tier-1 (13命令)**: NewBox, BoxFieldLoad, BoxFieldStore, BoxCall, **ExternCall**,
                   Safepoint, RefGet, RefSet, WeakNew, WeakLoad, WeakCheck, Send, Recv
**Tier-2 (5命令)**: TailCall, Adopt, Release, MemCopy, AtomicFence

## 🔥 ExternCall革命
外部ライブラリをBox統一APIで利用する革命的機能追加

## 📚 新規ドキュメント
- docs/nyir/: NyIR公開仕様フォルダ新設
- box_ffi_abi.md: Box FFI/ABI完全設計(ChatGPT5)
- phase_9_7実装仕様: GitHub Issue #72準備完了

## 🚀 次期タスク
Phase 9.7: Box FFI/ABI実装(Issue #72)
- MIR ExternCall命令実装
- WASM RuntimeImports統合
- Universal Library Integration実現

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-14 17:26:04 +09:00
8443635380 feat: Phase 9実用優先戦略・詳細設計ドキュメント完成
Phase 8完全完了記念!実用価値最大化でPhase 9開始準備完了:

📋 新規作成ドキュメント:
- phase9_aot_wasm_implementation.md: AOT WASM実装詳細設計
  * wasmtime compile統合実装
  * 単一バイナリ梱包戦略
  * 2-3週間実装ステップ
- phase9_5_http_server_validation.md: HTTPサーバー実用テスト設計
  * 並行処理・メモリ管理検証
  * AOT性能実証計画
  * 配布可能サーバーデモ

🔄 既存ドキュメント更新:
- phase9_jit_baseline_planning.md: 実用優先戦略変更通知
- phase10_aot_scaffolding.md: LLVM Direct AOT完全再設計
- CURRENT_TASK.md: Phase 8完了・Phase 9戦略開始

🎯 実装目標:
- nyash --compile-native app.nyash -o app.exe
- 配布可能実行ファイル生成(500倍高速化目標)
- Everything is Box哲学のネイティブ最適化基盤

🚀 期待効果:
- 「おもちゃ言語」からの卒業
- 短期間で確実な実用価値提供
- Phase 10 LLVM最適化への技術基盤確立

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-14 13:10:53 +09:00
890b58a19e docs: 実用優先戦略でPhase 9-10完全再設計
Phase 8.6+8.7完了受けて、実用価値最大化戦略に基づく設計変更:

📋 Phase 9-10再設計:
- Phase 9: JIT planning → AOT WASM実装(最優先・2-3週間)
- Phase 9.5: HTTPサーバー実用テスト追加(AOT検証・2週間)
- Phase 10: AOT exploration → LLVM Direct AOT(最高性能・4-6ヶ月)
- Cranelift JIT: Phase 12以降の将来オプションに変更

🎯 実用優先戦略の根拠:
- WASM既に動作済み(13.5倍高速化実証済み)
- AOT実装で即座配布価値提供
- Cranelift JITは重複投資(Rust開発環境改善効果限定)
- 時間効率:2-3ヶ月節約でLLVM集中投資

🚀 期待効果:
- `nyash --compile-native app.nyash -o app.exe` 実現
- 配布可能HTTPサーバーデモ(Phase 9.5)
- Everything is Box哲学のネイティブ最適化
- 1000倍高速化目標(Phase 10)

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-14 13:00:44 +09:00
ee4228af5a docs(phase-8.5): Add comprehensive MIR 25-instruction specification
• Phase 8.5 complete specification (ChatGPT5 + AI conference decision)
• 25-instruction semantic layering (Tier-0/1/2 structure)
• Effect system (pure/mut/io/control) with optimization rules
• Verifier requirements (ownership forest, weak references, safety)
• Backend implementation guidance (Interpreter/VM/WASM/JIT)
• Two-phase lowering strategy for flexible backend support
• Test strategies (Golden MIR, behavior consistency, performance)

Addresses VM/WASM issues discovered in Phase 8.4 testing:
- VM BoxCall return value problem
- WASM String constant/BoxCall support
- Everything is Box philosophy perfect IR realization

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-14 11:14:24 +09:00
8ec80a35c3 feat(benchmark): add comprehensive performance benchmarking system
🚀 Phase 8.2 PoC2 Achievement: 280x WASM performance boost proven\!

## New Features:
- Complete benchmark framework (src/benchmarks.rs)
- CLI integration: --benchmark --iterations options
- 3-backend comparison: Interpreter/VM/WASM
- Automated performance measurement & reporting

## Benchmark Results (100 iterations average):
- WASM: 0.17ms (280x faster than Interpreter\!)
- VM: 16.97ms (2.9x faster than Interpreter)
- Interpreter: 48.59ms (baseline)

## Added Files:
- benchmarks/bench_{light,medium,heavy}.nyash - Test cases
- benchmark_summary_20250814.md - Clean results
- wasm_demo/ - Browser execution environment

## Documentation Updates:
- docs/execution-backends.md - Added benchmark usage
- docs/CURRENT_TASK.md - Phase 8.3 Copilot coordination
- CLAUDE.md - Quick benchmark access

## Copilot Integration Ready:
- Phase 8.3 merge conflict avoidance strategy documented
- Benchmark framework ready for Box operation performance validation
- CLI integration preserved for future enhancements

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-14 07:19:23 +09:00
2c485c9444 docs(phase8.3): update Issue #53 with current progress and Copilot guidance
- Update current state with Phase 8.2 PoC2/PoC3 completion
- Add comprehensive test cases for Copilot implementation
- Include implementation guidance and quality assurance checklist
- Add technical baseline info (CLI, browser test env, docs)
- Provide RefNew implementation example for reference

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-14 06:51:07 +09:00
42379a3694 docs: update Phase 7 planning and add correct Nyash philosophy test files
- Update CLAUDE.md with 32-thread build option
- Enhance phase7_async_mir.md with detailed implementation plan
- Add Obj class definition to phase6_ref_set_get.nyash
- Create phase6_ref_set_get_correct.nyash following Everything is Box philosophy
2025-08-13 21:06:37 +09:00
5cbd8a7f82 docs(native-plan): add issue stubs for Phase 9 (JIT baseline), Phase 10 (AOT scaffolding), Phase 14 (Packaging/CI) 2025-08-13 18:54:03 +09:00
fbc3cd9876 docs(native-plan): add Phase 8 MIR→WASM detailed issue; align copilot_issues index; expand README phase 8 section 2025-08-13 18:54:02 +09:00
621bf7cc3d docs: reorganize into 説明書/予定/archive; update docs/README.md and CLAUDE.md; move root .nyash to local_tests; consolidate native-plan notes into README + archive 2025-08-13 18:54:02 +09:00