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-09-17 07:43:07 +09:00
|
|
|
use crate::runtime::{
|
|
|
|
|
get_global_plugin_host, get_global_registry, init_global_plugin_host, PluginConfig,
|
|
|
|
|
};
|
2025-08-26 04:34:14 +09:00
|
|
|
|
2025-11-06 15:41:52 +09:00
|
|
|
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");
|
2025-11-21 06:25:17 +09:00
|
|
|
if p.exists() {
|
|
|
|
|
return p.to_string_lossy().to_string();
|
|
|
|
|
}
|
2025-11-06 15:41:52 +09:00
|
|
|
let p2 = std::path::Path::new(&root).join("nyash.toml");
|
2025-11-21 06:25:17 +09:00
|
|
|
if p2.exists() {
|
|
|
|
|
return p2.to_string_lossy().to_string();
|
|
|
|
|
}
|
2025-11-06 15:41:52 +09:00
|
|
|
}
|
|
|
|
|
"nyash.toml".to_string()
|
|
|
|
|
}
|
|
|
|
|
|
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");
|
2025-09-17 07:43:07 +09:00
|
|
|
if plugin_debug {
|
|
|
|
|
eprintln!("🔍 DEBUG: Initializing v2 plugin system");
|
|
|
|
|
}
|
2025-08-26 04:34:14 +09:00
|
|
|
|
2025-11-06 15:41:52 +09:00
|
|
|
let cfg_path = resolve_plugin_toml();
|
|
|
|
|
if let Ok(()) = init_global_plugin_host(&cfg_path) {
|
2025-08-26 04:34:14 +09:00
|
|
|
if plugin_debug || cli_verbose {
|
2025-11-06 15:41:52 +09:00
|
|
|
eprintln!("🔌 plugin host initialized from {}", cfg_path);
|
2025-09-06 06:24:08 +09:00
|
|
|
// Show which plugin loader backend compiled in (enabled/stub)
|
2025-09-17 07:43:07 +09:00
|
|
|
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 {
|
2025-09-17 07:43:07 +09:00
|
|
|
if plugin_debug {
|
|
|
|
|
eprintln!(" 📦 Registering plugin provider for {}", box_name);
|
|
|
|
|
}
|
|
|
|
|
registry.apply_plugin_config(&PluginConfig {
|
|
|
|
|
plugins: [(box_name.clone(), lib_name.clone())].into(),
|
|
|
|
|
});
|
2025-08-26 04:34:14 +09:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
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
|
|
|
}
|
|
|
|
|
}
|
2025-11-13 16:40:58 +09:00
|
|
|
|
|
|
|
|
// Optional autoload for [using.*] kind="dylib" packages
|
|
|
|
|
if std::env::var("NYASH_USING_DYLIB_AUTOLOAD").ok().as_deref() == Some("1")
|
|
|
|
|
&& std::env::var("NYASH_DISABLE_PLUGINS").ok().as_deref() != Some("1")
|
|
|
|
|
{
|
2025-11-21 06:25:17 +09:00
|
|
|
if plugin_debug || cli_verbose {
|
|
|
|
|
eprintln!("[using.dylib/autoload] scanning nyash.toml packages …");
|
|
|
|
|
}
|
2025-11-13 16:40:58 +09:00
|
|
|
let mut using_paths: Vec<String> = Vec::new();
|
|
|
|
|
let mut pending_modules: std::vec::Vec<(String, String)> = Vec::new();
|
2025-11-21 06:25:17 +09:00
|
|
|
let mut aliases: std::collections::HashMap<String, String> =
|
|
|
|
|
std::collections::HashMap::new();
|
|
|
|
|
let mut packages: std::collections::HashMap<String, crate::using::spec::UsingPackage> =
|
|
|
|
|
std::collections::HashMap::new();
|
2025-11-13 16:40:58 +09:00
|
|
|
let _ = crate::using::resolver::populate_from_toml(
|
|
|
|
|
&mut using_paths,
|
|
|
|
|
&mut pending_modules,
|
|
|
|
|
&mut aliases,
|
|
|
|
|
&mut packages,
|
|
|
|
|
);
|
|
|
|
|
for (name, pkg) in packages.iter() {
|
|
|
|
|
if let crate::using::spec::PackageKind::Dylib = pkg.kind {
|
|
|
|
|
// Build library name from file stem (best-effort)
|
|
|
|
|
let lib_name = std::path::Path::new(&pkg.path)
|
|
|
|
|
.file_name()
|
|
|
|
|
.and_then(|s| s.to_str())
|
|
|
|
|
.unwrap_or(name)
|
|
|
|
|
.to_string();
|
|
|
|
|
let host = get_global_plugin_host();
|
|
|
|
|
let res = host
|
|
|
|
|
.read()
|
|
|
|
|
.unwrap()
|
|
|
|
|
.load_library_direct(&lib_name, &pkg.path, &[]);
|
|
|
|
|
if let Err(e) = res {
|
|
|
|
|
if plugin_debug || cli_verbose {
|
|
|
|
|
eprintln!("[using.dylib/autoload] failed '{}': {}", lib_name, e);
|
|
|
|
|
}
|
|
|
|
|
} else if plugin_debug || cli_verbose {
|
2025-11-21 06:25:17 +09:00
|
|
|
eprintln!(
|
|
|
|
|
"[using.dylib/autoload] loaded '{}' from {}",
|
|
|
|
|
lib_name, pkg.path
|
|
|
|
|
);
|
2025-11-13 16:40:58 +09:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-08-26 04:34:14 +09:00
|
|
|
} else if plugin_debug || cli_verbose {
|
2025-11-06 15:41:52 +09:00
|
|
|
eprintln!("⚠️ Failed to load plugin config (hakorune.toml/nyash.toml) - plugins disabled");
|
2025-08-26 04:34:14 +09:00
|
|
|
}
|
|
|
|
|
}
|