feat: using system完全実装完了!nyashstdビルトイン名前空間対応

 実装内容:
- ビルトイン名前空間解決: nyashstd → builtin:nyashstd
- 自動コード生成: static box群(string/integer/bool/array/console)
- 環境変数デフォルト化: NYASH_ENABLE_USING, NYASH_RESOLVE_FIX_BRACES, NYASH_LLVM_USE_HARNESS

 動作確認:
- パース→解決→読み込み→コード生成の全段階が正常動作
- 環境変数8個→6個に削減(25%改善)

 主要変更:
- src/runner/pipeline.rs: builtin namespace特別処理追加
- src/runner/modes/common_util/resolve/strip.rs: builtin:プレフィックス処理
- src/config/env.rs: 3つの環境変数をデフォルトON化

🎯 次: Mini-VM開発でusing nyashstd活用可能

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

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
Selfhosting Dev
2025-09-23 12:39:35 +09:00
parent bbc581a07f
commit b7a3e129bd
4 changed files with 116 additions and 23 deletions

View File

@ -181,11 +181,14 @@ NYASH_DISABLE_PLUGINS=1 ./target/release/nyash program.nyash
# 🔍 デバッグ情報が欲しいときはこれ
NYASH_CLI_VERBOSE=1 ./target/release/nyash program.nyash
# ⚡ 高性能実行LLVM
# ⚡ 高性能実行LLVM Pythonハーネス
./target/release/nyash --backend llvm program.nyash
# 🧪 using系テストPhase 15
NYASH_DISABLE_PLUGINS=1 NYASH_ENABLE_USING=1 NYASH_VM_USE_PY=1 ./target/release/nyash program.nyash
# PyVM使用
NYASH_DISABLE_PLUGINS=1 NYASH_VM_USE_PY=1 ./target/release/nyash program.nyash
# LLVM使用
NYASH_DISABLE_PLUGINS=1 ./target/release/nyash --backend llvm program.nyash
```
### 🚨 **Phase 15重要注意**
@ -199,32 +202,37 @@ NYASH_DISABLE_PLUGINS=1 NYASH_ENABLE_USING=1 NYASH_VM_USE_PY=1 ./target/release/
|---------|-------|-----|-------------|
| `NYASH_DISABLE_PLUGINS=1` | ⭐⭐⭐ | エラー対策 | プラグインエラー時 |
| `NYASH_CLI_VERBOSE=1` | ⭐⭐ | デバッグ | 詳細情報が欲しい時 |
| `NYASH_ENABLE_USING=1` | ⭐⭐ | Phase 15 | using構文テスト時 |
| ~~`NYASH_ENABLE_USING=1`~~ | | Phase 15 | ~~デフォルト化済み~~ |
| `NYASH_VM_USE_PY=1` | ⭐ | Phase 15 | PyVM経路使用時 |
| `NYASH_DUMP_JSON_IR=1` | ⭐ | 開発 | JSON出力確認時 |
**💡 覚え方**:迷ったら`NYASH_DISABLE_PLUGINS=1`から試す!
### ⚠️ **using system環境変数地獄(要整理)**
### **using system完全実装完了!**
**現状**: using関連テストに**8個**の環境変数が必要で複雑すぎる状況
**🎉 歴史的快挙**: `using nyashstd`が完璧動作!環境変数を**8個→6個**に削減25%改善)
**✅ 実装完了内容**
- **ビルトイン名前空間解決**: `nyashstd``builtin:nyashstd`の自動解決
- **自動コード生成**: nyashstdのstatic box群string, integer, bool, array, consoleを動的生成
- **環境変数デフォルト化**: NYASH_ENABLE_USING, NYASH_RESOLVE_FIX_BRACES, NYASH_LLVM_USE_HARNESS
**✅ 動作確認済み**
```bash
# using混在スモークテスト用の環境変数地獄
NYASH_ENABLE_USING=1 # using構文有効化
NYASH_VM_USE_PY=1 # PyVM使用
NYASH_LOAD_NY_PLUGINS=1 # Nyプラグイン読み込
NYASH_RESOLVE_FIX_BRACES=1 # ブレース修正
NYASH_PARSER_STATIC_INIT_STRICT=1 # パーサー厳格モード
NYASH_PYVM_DUMP_CODE=1 # PyVMコードダンプ
NYASH_RESOLVE_SEAM_DEBUG=1 # seam結合デバッグ
NYASH_RESOLVE_DEDUP_BOX=1 # 重複Box削除
# 基本using動作(パース→解決→読み込み→コード生成すべて成功)
./target/release/nyash program_with_using.nyash
# ログ確認済
[using/resolve] builtin 'nyashstd' -> 'builtin:nyashstd' ✅ 解決成功
[using] loaded builtin namespace: builtin:nyashstd ✅ 読み込み成功
```
**問題**:
- 🔥 認知負荷高すぎ8個は覚えられない
- 🔥 相互依存性不明(どれが必須?)
- 🔥 組み合わせ爆発2^8 = 256通り
- 🔥 デバッグ困難(どれが原因?)
**📦 含まれるnyashstd機能**
- `string.create(text)`, `string.upper(str)`
- `integer.create(value)`, `bool.create(value)`, `array.create()`
- `console.log(message)`
**🎯 次のステップ**: Mini-VM開発で`using nyashstd`を活用可能!
**将来の簡略化案**:
- `NYASH_USING_PROFILE=dev|smoke|debug` でプロファイル化

View File

@ -133,7 +133,12 @@ pub fn verify_edge_copy_strict() -> bool {
// ---- LLVM harness toggle (llvmlite) ----
pub fn llvm_use_harness() -> bool {
std::env::var("NYASH_LLVM_USE_HARNESS").ok().as_deref() == Some("1")
// Phase 15: デフォルトONLLVMバックエンドはPythonハーネス使用
// NYASH_LLVM_USE_HARNESS=0 で明示的に無効化可能
match std::env::var("NYASH_LLVM_USE_HARNESS").ok().as_deref() {
Some("0") | Some("false") | Some("off") => false,
_ => true, // デフォルト: ONハーネス使用
}
}
// ---- Phase 11.8 MIR cleanup toggles ----
@ -323,7 +328,20 @@ pub fn cli_verbose() -> bool {
std::env::var("NYASH_CLI_VERBOSE").ok().as_deref() == Some("1")
}
pub fn enable_using() -> bool {
std::env::var("NYASH_ENABLE_USING").ok().as_deref() == Some("1")
// Phase 15: デフォルトONusing systemはメイン機能
// NYASH_ENABLE_USING=0 で明示的に無効化可能
match std::env::var("NYASH_ENABLE_USING").ok().as_deref() {
Some("0") | Some("false") | Some("off") => false,
_ => true, // デフォルト: ON
}
}
pub fn resolve_fix_braces() -> bool {
// Phase 15: デフォルトONusing時のブレース均等修正が必須
// NYASH_RESOLVE_FIX_BRACES=0 で明示的に無効化可能
match std::env::var("NYASH_RESOLVE_FIX_BRACES").ok().as_deref() {
Some("0") | Some("false") | Some("off") => false,
_ => enable_using(), // using有効時は自動でON
}
}
pub fn vm_use_py() -> bool {
std::env::var("NYASH_VM_USE_PY").ok().as_deref() == Some("1")

View File

@ -1,6 +1,56 @@
use crate::runner::NyashRunner;
use std::collections::HashSet;
/// Generate content for built-in namespaces like builtin:nyashstd
fn generate_builtin_namespace_content(namespace_key: &str) -> String {
match namespace_key {
"builtin:nyashstd" => {
// Generate Nyash code that provides nyashstd functionality
// This exposes the built-in stdlib boxes as regular Nyash static boxes
format!(r#"
// Built-in nyashstd namespace (auto-generated)
static box string {{
create(text) {{
return new StringBox(text)
}}
upper(str) {{
return new StringBox(str.upper())
}}
}}
static box integer {{
create(value) {{
return new IntegerBox(value)
}}
}}
static box bool {{
create(value) {{
return new BoolBox(value)
}}
}}
static box array {{
create() {{
return new ArrayBox()
}}
}}
static box console {{
log(message) {{
print(message)
return null
}}
}}
"#)
}
_ => {
// Unknown built-in namespace
format!("// Unknown built-in namespace: {}\n", namespace_key)
}
}
}
/// Strip `using` lines and register modules/aliases into the runtime registry.
/// Returns cleaned source. No-op when `NYASH_ENABLE_USING` is not set.
#[allow(dead_code)]
@ -14,7 +64,7 @@ pub fn strip_using_and_register(
}
// Optional external combiner (default OFF): NYASH_USING_COMBINER=1
if std::env::var("NYASH_USING_COMBINER").ok().as_deref() == Some("1") {
let fix_braces = std::env::var("NYASH_RESOLVE_FIX_BRACES").ok().as_deref() == Some("1");
let fix_braces = crate::config::env::resolve_fix_braces();
let dedup_box = std::env::var("NYASH_RESOLVE_DEDUP_BOX").ok().as_deref() == Some("1");
let dedup_fn = std::env::var("NYASH_RESOLVE_DEDUP_FN").ok().as_deref() == Some("1");
let seam_dbg = std::env::var("NYASH_RESOLVE_SEAM_DEBUG").ok().as_deref() == Some("1");
@ -176,6 +226,14 @@ pub fn strip_using_and_register(
prelude.push_str(&inlined);
prelude.push_str("\n");
crate::runner::modes::common_util::resolve::seam::log_inlined_tail(&key, &inlined, seam_dbg);
} else if key.starts_with("builtin:") {
// Handle built-in namespaces like builtin:nyashstd
let builtin_content = generate_builtin_namespace_content(&key);
prelude.push_str(&builtin_content);
prelude.push_str("\n");
if verbose {
eprintln!("[using] loaded builtin namespace: {}", key);
}
} else if verbose {
eprintln!("[using] warn: could not read {}", p.display());
}

View File

@ -242,7 +242,16 @@ pub(super) fn resolve_using_target(
crate::runner::box_index::cache_put(&key, out.clone());
return Ok(out);
}
// 2) build candidate list: relative then using-paths
// 2) Special handling for built-in namespaces
if tgt == "nyashstd" {
let out = "builtin:nyashstd".to_string();
if trace {
crate::runner::trace::log(format!("[using/resolve] builtin '{}' -> '{}'", tgt, out));
}
crate::runner::box_index::cache_put(&key, out.clone());
return Ok(out);
}
// 3) build candidate list: relative then using-paths
let rel = tgt.replace('.', "/") + ".nyash";
let mut cand: Vec<String> = Vec::new();
if let Some(dir) = context_dir {