2025-08-26 04:34:14 +09:00
|
|
|
/*!
|
|
|
|
|
* Runner plugin initialization (extracted from runner.rs)
|
|
|
|
|
*
|
|
|
|
|
* Purpose: Initialize v2 plugin system from nyash.toml and apply config
|
|
|
|
|
* Behavior: Quiet by default; use NYASH_CLI_VERBOSE=1 or NYASH_DEBUG_PLUGIN=1 for logs
|
|
|
|
|
*/
|
|
|
|
|
|
2025-08-26 19:13:57 +09:00
|
|
|
use crate::runtime::{init_global_plugin_host, get_global_registry, get_global_plugin_host, PluginConfig};
|
2025-08-26 04:34:14 +09:00
|
|
|
|
|
|
|
|
pub fn init_bid_plugins() {
|
|
|
|
|
let cli_verbose = std::env::var("NYASH_CLI_VERBOSE").ok().as_deref() == Some("1");
|
|
|
|
|
let plugin_debug = std::env::var("NYASH_DEBUG_PLUGIN").ok().as_deref() == Some("1");
|
|
|
|
|
if plugin_debug { eprintln!("🔍 DEBUG: Initializing v2 plugin system"); }
|
|
|
|
|
|
2025-08-26 19:13:57 +09:00
|
|
|
if let Ok(()) = init_global_plugin_host("nyash.toml") {
|
2025-08-26 04:34:14 +09:00
|
|
|
if plugin_debug || cli_verbose {
|
2025-09-08 04:35:50 +09:00
|
|
|
eprintln!("🔌 plugin host initialized from nyash.toml");
|
2025-09-06 06:24:08 +09:00
|
|
|
// Show which plugin loader backend compiled in (enabled/stub)
|
|
|
|
|
println!("[plugin-loader] backend={}", crate::runtime::plugin_loader_v2::backend_kind());
|
2025-08-26 04:34:14 +09:00
|
|
|
}
|
2025-08-26 19:13:57 +09:00
|
|
|
let host = get_global_plugin_host();
|
|
|
|
|
let host = host.read().unwrap();
|
|
|
|
|
if let Some(config) = host.config_ref() {
|
2025-08-26 04:34:14 +09:00
|
|
|
let registry = get_global_registry();
|
|
|
|
|
for (lib_name, lib_def) in &config.libraries {
|
|
|
|
|
for box_name in &lib_def.boxes {
|
|
|
|
|
if plugin_debug { eprintln!(" 📦 Registering plugin provider for {}", box_name); }
|
|
|
|
|
registry.apply_plugin_config(&PluginConfig { plugins: [(box_name.clone(), lib_name.clone())].into(), });
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if plugin_debug || cli_verbose {
|
2025-09-08 04:35:50 +09:00
|
|
|
eprintln!("✅ plugin host fully configured");
|
2025-08-26 04:34:14 +09:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} else if plugin_debug || cli_verbose {
|
|
|
|
|
eprintln!("⚠️ Failed to load nyash.toml - plugins disabled");
|
|
|
|
|
}
|
|
|
|
|
}
|