99f57ef27d
feat(phase113): FileHandleBox Nyash 公開 API 完成
...
FileHandleBox の内部メソッド(open/read/write/close/exists/size)を
Nyash (.hako) 側から「普通の Box メソッド」として使える形に完全公開
【実装内容】
Task 1: 公開 API 設計書完成
- phase113_filehandlebox_public_api.md 作成(380行完全仕様書)
- I/O メソッド: open(path, mode) / read() / write(text) / close()
- メタデータメソッド: exists() / size() / isFile() / isDir()
- Profile 別動作: Default (全機能) / NoFs (open で panic)
Task 2: Rust 側メソッド公開
- FileHandleBox に ny_* メソッド実装(8メソッド)
- BoxFactory 登録完了
- StringBox と同じ invoke_method() パターン採用
Task 3: .hako サンプル & テスト
- append_and_stat.hako サンプル作成(実用例)
- Rust ユニットテスト 6個(全メソッド + Profile カバレッジ)
Task 4: Profile 統合確認
- Default プロファイル: 全機能正常動作 ✅
- NoFs プロファイル: open は panic、cascade disabled ✅
- Ring0Registry による自動無効化パターン確立 ✅
Task 5: ドキュメント完全更新
- core_boxes_design.md: Section 16.1 追加(88行)
- ring0-inventory.md: Phase 113 エントリ追加(8行)
- CURRENT_TASK.md: Phase 113 完了マーク
【統計】
- 新規作成: 3ファイル(.md + .hako + factory)
- 修正: 6ファイル
- 追加行数: +210行
- テスト: 6個(全 PASS)
- ビルド: SUCCESS
【Phase 106-113 通算】
- 7フェーズ完成
- 33+17=50ファイル修正
- +1,350+210=+1,560行実装
- 設計書: 6つの大規模 markdown
- テスト: 33+6=39個全PASS
- 第1章完結状態に到達 ✅
【設計原則確立】
- Ring0 → Ring1 FS API の完全統一
- Profile-aware 初期化(SSOT パターン)
- FileBox / FileHandleBox / Ring0 の非矛盾性設計
- .hako 入口から Rust 実装まで全導線完備
🤖 Generated with Claude Code
Co-Authored-By: Claude <noreply@anthropic.com >
2025-12-04 03:35:25 +09:00
a3d5bacc55
Phase 30.1 & 73: Stage-3 features env and JoinIR flag cleanup
2025-11-30 14:30:28 +09:00
f4ae144559
fix(using): StringUtils using resolution - dual root cause fix
...
🎯 Phase 21.7++ - using StringUtils as StringUtils 完全動作化!
## Root Cause #1 : TOML Parse Error (lang/src/llvm_ir/hako_module.toml)
**Problem:**
```toml
line 18: aot_prep = "boxes/aot_prep.hako" # scalar
line 19: aot_prep.passes.strlen = "..." # table - CONFLICT!
```
→ TOML parse error prevented ALL aliases from loading
→ populate_from_toml() returned Err, aliases.len() = 0
**Fix:**
Commented out conflicting line 18:
```toml
# aot_prep = "boxes/aot_prep.hako" # Commented out: conflicts with aot_prep.passes.* below
aot_prep.passes.strlen = "boxes/aot_prep/passes/strlen.hako"
```
**Result:**
✅ populate_from_toml() succeeds
✅ 4 aliases loaded including StringUtils → string_utils
## Root Cause #2 : Missing Arity Suffix (src/backend/mir_interpreter/handlers/calls/global.rs)
**Problem:**
- MIR functions stored as "BoxName.method/arity"
- VM looked up "StringUtils.starts_with" (no arity)
- Function table had "StringUtils.starts_with/2" (with /2)
→ Lookup failed with "Unknown: StringUtils.starts_with"
**Fix:**
Auto-append arity from args.len() if missing:
```rust
let mut canonical = crate::mir::naming::normalize_static_global_name(func_name);
if !canonical.contains('/') {
canonical = format!("{}/{}", canonical, args.len());
}
```
**Result:**
✅ "StringUtils.starts_with" + args.len()=2 → "StringUtils.starts_with/2"
✅ VM function lookup succeeds
## Debug Infrastructure
**Added comprehensive debug logging:**
1. src/runner/pipeline.rs:36-55 - NYASH_DEBUG_USING=1 for alias loading
2. src/backend/mir_interpreter/handlers/calls/global.rs:17-42 - NYASH_DEBUG_FUNCTION_LOOKUP=1 for VM lookup
## Test Coverage
**src/tests/json_lint_stringutils_min_vm.rs:**
- Rewrote to test arity auto-completion (not using resolution)
- Inlined StringUtils implementation to avoid pipeline dependency
- Tests that VM can call "StringUtils.starts_with" without arity suffix
- ✅ Test passes
**CLI Verification:**
```bash
NYASH_PARSER_STAGE3=1 HAKO_PARSER_STAGE3=1 NYASH_DISABLE_PLUGINS=1 \
./target/release/hakorune apps/tests/json_lint_stringutils_min.hako
# Output: OK
# RC: 0
```
## Impact
- ✅ using StringUtils as StringUtils fully functional
- ✅ All using aliases load successfully
- ✅ VM can find functions with/without arity suffix
- ✅ No breaking changes to existing code
- ✅ Debug logging for future troubleshooting
## Files Modified
- lang/src/llvm_ir/hako_module.toml (TOML fix)
- src/runner/pipeline.rs (debug logging)
- src/backend/mir_interpreter/handlers/calls/global.rs (arity fix + logging)
- src/tests/json_lint_stringutils_min_vm.rs (rewrite + enable)
- src/tests/mod.rs (register test)
Co-authored-by: Task Agent <task@anthropic.com >
Co-authored-by: Claude Code <claude@anthropic.com >
2025-11-22 01:21:38 +09:00
dda65b94b7
Phase 21.7 normalization: optimization pre-work + bench harness expansion
...
- Add opt-in optimizations (defaults OFF)
- Ret purity verifier: NYASH_VERIFY_RET_PURITY=1
- strlen FAST enhancement for const handles
- FAST_INT gate for same-BB SSA optimization
- length cache for string literals in llvmlite
- Expand bench harness (tools/perf/microbench.sh)
- Add branch/call/stringchain/arraymap/chip8/kilo cases
- Auto-calculate ratio vs C reference
- Document in benchmarks/README.md
- Compiler health improvements
- Unify PHI insertion to insert_phi_at_head()
- Add NYASH_LLVM_SKIP_BUILD=1 for build reuse
- Runtime & safety enhancements
- Clarify Rust/Hako ownership boundaries
- Strengthen receiver localization (LocalSSA/pin/after-PHIs)
- Stop excessive PluginInvoke→BoxCall rewrites
- Update CURRENT_TASK.md, docs, and canaries
🤖 Generated with [Claude Code](https://claude.com/claude-code )
Co-Authored-By: Claude <noreply@anthropic.com >
2025-11-13 16:40:58 +09:00
77d4fd72b3
phase: 20.49 COMPLETE; 20.50 Flow+String minimal reps; 20.51 selfhost v0/v1 minimal (Option A/B); hv1-inline binop/unop/copy; docs + run_all + CURRENT_TASK -> 21.0
2025-11-06 15:41:52 +09:00
3aa0c3c875
fix(stage-b): Add sh_core using + Stage-1 JSON support
...
## Fixed Issues
1. compiler_stageb.hako: Added 'using sh_core as StringHelpers'
- Resolved: call unresolved ParserStringUtilsBox.skip_ws/2
- Root cause: using chain resolution not implemented
- Workaround: explicit using in parent file
2. stageb_helpers.sh: Accept Stage-1 JSON format
- Modified awk pattern to accept both formats:
- MIR JSON v0: "version":0, "kind":"Program"
- Stage-1 JSON: "type":"Program"
## Remaining Issues
ParserBox VM crash: Invalid value: use of undefined value ValueId(5839)
- Cause: Complex nested loops in parse_program2()
- Workaround: Minimal Stage-B (without ParserBox) works
- Fallback: Rust compiler path available
## Verification
✅ Minimal Stage-B outputs JSON correctly
❌ ParserBox execution crashes VM (SSA bug)
Co-Authored-By: Task先生 (AI Agent)
2025-11-02 08:23:43 +09:00
47bd2d2ee2
Gate‑C(Core) OOB strict fail‑fast; String VM handler normalization; JSON lint Stage‑B root fixes via scanner field boxing and BinOp operand slotify; docs + smokes update
2025-11-01 18:45:26 +09:00
dd65cf7e4c
builder+vm: unify method calls via emit_unified_call; add RouterPolicy trace; finalize LocalSSA/BlockSchedule guards; docs + selfhost quickstart
...
- Unify standard method calls to emit_unified_call; route via RouterPolicy and apply rewrite::{special,known} at a single entry.\n- Stabilize emit-time invariants: LocalSSA finalize + BlockSchedule PHI→Copy→Call ordering; metadata propagation on copies.\n- Known rewrite default ON (userbox only, strict guards) with opt-out flag NYASH_REWRITE_KNOWN_DEFAULT=0.\n- Expand TypeAnnotation whitelist (is_digit_char/is_hex_digit_char/is_alpha_char/Map.has).\n- Docs: unified-method-resolution design note; Quick Reference normalization note; selfhosting/quickstart.\n- Tools: add tools/selfhost_smoke.sh (dev-only).\n- Keep behavior unchanged for Unknown/core/user-instance via BoxCall fallback; all tests green (quick/integration).
2025-09-28 20:38:09 +09:00
34be7d2d79
vm/router: minimal special-method extension (equals/1); toString mapping kept
...
mir: add TypeCertainty to Callee::Method (diagnostic only); plumb through builder/JSON/printer; backends ignore behaviorally
using: confirm unified prelude resolver entry for all runner modes
docs: update Callee architecture with certainty; update call-instructions; CURRENT_TASK note
tests: quick 40/40 PASS; integration (LLVM) 17/17 PASS
2025-09-28 01:33:58 +09:00
cb236b7f5a
json(vm): fix birth dispatch; unify constructor naming (Box.birth/N); JsonNode factories return JsonNodeInstance; quick: enable heavy JSON with probe; builder: NYASH_BUILDER_DEBUG_LIMIT guard; json_query_min(core) harness; docs/tasks updated
2025-09-27 08:45:25 +09:00
e323120c59
phase15: update CLAUDE.md with Phase 15 enhancements from AGENTS.md
...
- Add JIT Self-Host Quickstart section for Phase 15
- Include important flags reference (plugins, parsers, debugging)
- Add Codex async workflow documentation for parallel tasks
- Update test execution with Phase 15 smoke tests
- Improve build time notes (JIT vs LLVM)
- Align with current Phase 15 progress and tooling
🎉 Bootstrap (c0→c1→c1') test confirmed working\!
Co-Authored-By: Claude <noreply@anthropic.com >
2025-09-05 15:18:13 +09:00