Files
hakorune/src/runner_plugin_init.rs

70 lines
2.7 KiB
Rust
Raw Normal View History

/*!
* 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
*/
use crate::runtime::{
get_global_plugin_host, get_global_registry, init_global_plugin_host, PluginConfig,
};
fn resolve_plugin_toml() -> String {
// Prefer hakorune.toml, fallback to nyash.toml (check CWD, then NYASH_ROOT)
let cwd_hako = std::path::Path::new("hakorune.toml");
if cwd_hako.exists() {
return "hakorune.toml".to_string();
}
let cwd_ny = std::path::Path::new("nyash.toml");
if cwd_ny.exists() {
return "nyash.toml".to_string();
}
if let Ok(root) = std::env::var("NYASH_ROOT") {
let p = std::path::Path::new(&root).join("hakorune.toml");
if p.exists() { return p.to_string_lossy().to_string(); }
let p2 = std::path::Path::new(&root).join("nyash.toml");
if p2.exists() { return p2.to_string_lossy().to_string(); }
}
"nyash.toml".to_string()
}
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");
}
let cfg_path = resolve_plugin_toml();
if let Ok(()) = init_global_plugin_host(&cfg_path) {
if plugin_debug || cli_verbose {
eprintln!("🔌 plugin host initialized from {}", cfg_path);
// Show which plugin loader backend compiled in (enabled/stub)
println!(
"[plugin-loader] backend={}",
crate::runtime::plugin_loader_v2::backend_kind()
);
}
let host = get_global_plugin_host();
let host = host.read().unwrap();
if let Some(config) = host.config_ref() {
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 {
eprintln!("✅ plugin host fully configured");
}
}
} else if plugin_debug || cli_verbose {
eprintln!("⚠️ Failed to load plugin config (hakorune.toml/nyash.toml) - plugins disabled");
}
}