runner: split modes (mir/vm/llvm/bench) and extract plugin init; interpreter: split objects into ops/methods/fields; VM logs gated; Phi selection minimal fix; CURRENT_TASK updated; remove legacy backups
This commit is contained in:
36
src/runner_plugin_init.rs
Normal file
36
src/runner_plugin_init.rs
Normal file
@ -0,0 +1,36 @@
|
||||
/*!
|
||||
* 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::{init_global_loader_v2, get_global_registry, get_global_loader_v2, PluginConfig};
|
||||
|
||||
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"); }
|
||||
|
||||
if let Ok(()) = init_global_loader_v2("nyash.toml") {
|
||||
if plugin_debug || cli_verbose {
|
||||
println!("🔌 v2 plugin system initialized from nyash.toml");
|
||||
}
|
||||
let loader = get_global_loader_v2();
|
||||
let loader = loader.read().unwrap();
|
||||
if let Some(config) = &loader.config {
|
||||
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 {
|
||||
println!("✅ v2 plugin system fully configured");
|
||||
}
|
||||
}
|
||||
} else if plugin_debug || cli_verbose {
|
||||
eprintln!("⚠️ Failed to load nyash.toml - plugins disabled");
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user