Phase 25.1 完了成果: - ✅ LoopForm v2 テスト・ドキュメント・コメント完備 - 4ケース(A/B/C/D)完全テストカバレッジ - 最小再現ケース作成(SSAバグ調査用) - SSOT文書作成(loopform_ssot.md) - 全ソースに [LoopForm] コメントタグ追加 - ✅ Stage-1 CLI デバッグ環境構築 - stage1_cli.hako 実装 - stage1_bridge.rs ブリッジ実装 - デバッグツール作成(stage1_debug.sh/stage1_minimal.sh) - アーキテクチャ改善提案文書 - ✅ 環境変数削減計画策定 - 25変数の完全調査・分類 - 6段階削減ロードマップ(25→5、80%削減) - 即時削除可能変数特定(NYASH_CONFIG/NYASH_DEBUG) Phase 26-D からの累積変更: - PHI実装改善(ExitPhiBuilder/HeaderPhiBuilder等) - MIRビルダーリファクタリング - 型伝播・最適化パス改善 - その他約300ファイルの累積変更 🎯 技術的成果: - SSAバグ根本原因特定(条件分岐内loop変数変更) - Region+next_iパターン適用完了(UsingCollectorBox等) - LoopFormパターン文書化・テスト化完了 - セルフホスティング基盤強化 Co-Authored-By: Claude <noreply@anthropic.com> Co-Authored-By: ChatGPT <noreply@openai.com> Co-Authored-By: Task Assistant <task@anthropic.com>
74 lines
2.9 KiB
Rust
74 lines
2.9 KiB
Rust
use super::*;
|
|
|
|
impl MirInterpreter {
|
|
pub(super) fn execute_extern_function(
|
|
&mut self,
|
|
extern_name: &str,
|
|
args: &[ValueId],
|
|
) -> Result<VMValue, VMError> {
|
|
// Normalize arity suffix (e.g., "env.get/1" -> "env.get")
|
|
let base = super::super::utils::normalize_arity_suffix(extern_name);
|
|
if let Some(res) = self.extern_provider_dispatch(base, args) {
|
|
if std::env::var("HAKO_CABI_TRACE").ok().as_deref() == Some("1") {
|
|
eprintln!("[hb:dispatch:calls] provider {}", base);
|
|
}
|
|
return res;
|
|
}
|
|
match base {
|
|
// Minimal console externs
|
|
"nyash.console.log" | "env.console.log" | "print" | "nyash.builtin.print" => {
|
|
if let Some(arg_id) = args.get(0) {
|
|
let v = self.reg_load(*arg_id)?;
|
|
match &v {
|
|
VMValue::Void => println!("null"),
|
|
VMValue::BoxRef(bx) => {
|
|
if bx
|
|
.as_any()
|
|
.downcast_ref::<crate::box_trait::VoidBox>()
|
|
.is_some()
|
|
{
|
|
println!("null");
|
|
} else if let Some(sb) =
|
|
bx.as_any().downcast_ref::<crate::box_trait::StringBox>()
|
|
{
|
|
println!("{}", sb.value);
|
|
} else {
|
|
println!("{}", v.to_string());
|
|
}
|
|
}
|
|
VMValue::String(s) => println!("{}", s),
|
|
_ => println!("{}", v.to_string()),
|
|
}
|
|
} else {
|
|
println!("");
|
|
}
|
|
Ok(VMValue::Void)
|
|
}
|
|
// Direct provider calls (bypass hostbridge.extern_invoke)
|
|
// Above provider covers env.* family; keep legacy fallbacks below
|
|
"exit" => {
|
|
let code = if let Some(arg_id) = args.get(0) {
|
|
self.reg_load(*arg_id)?.as_integer().unwrap_or(0)
|
|
} else {
|
|
0
|
|
};
|
|
std::process::exit(code as i32);
|
|
}
|
|
"panic" => {
|
|
let msg = if let Some(arg_id) = args.get(0) {
|
|
self.reg_load(*arg_id)?.to_string()
|
|
} else {
|
|
"VM panic".to_string()
|
|
};
|
|
panic!("{}", msg);
|
|
}
|
|
"hostbridge.extern_invoke" => Err(self.err_invalid(
|
|
"hostbridge.extern_invoke should be routed via extern_provider_dispatch",
|
|
)),
|
|
_ => {
|
|
Err(self.err_with_context("extern function", &format!("Unknown: {}", extern_name)))
|
|
}
|
|
}
|
|
}
|
|
}
|