...
This commit is contained in:
		| @@ -34,7 +34,6 @@ pub use os::{ | ||||
| pub use process::{ | ||||
|     register_process_module, | ||||
|     // Run functions | ||||
|     run, run_silent, run_with_options, new_run_options, | ||||
|     // Process management functions | ||||
|     which, kill, process_list, process_get | ||||
| }; | ||||
|   | ||||
| @@ -2,8 +2,9 @@ | ||||
| //! | ||||
| //! This module provides Rhai wrappers for the functions in the Process module. | ||||
|  | ||||
| use rhai::{Engine, EvalAltResult, Array, Dynamic, Map}; | ||||
| use rhai::{Engine, EvalAltResult, Array, Dynamic}; | ||||
| use crate::process::{self, CommandResult, ProcessInfo, RunError, ProcessError}; | ||||
| use std::clone::Clone; | ||||
|  | ||||
| /// Register Process module functions with the Rhai engine | ||||
| /// | ||||
| @@ -16,43 +17,36 @@ use crate::process::{self, CommandResult, ProcessInfo, RunError, ProcessError}; | ||||
| /// * `Result<(), Box<EvalAltResult>>` - Ok if registration was successful, Err otherwise | ||||
| pub fn register_process_module(engine: &mut Engine) -> Result<(), Box<EvalAltResult>> { | ||||
|     // Register types | ||||
|     register_process_types(engine)?; | ||||
|      | ||||
|     // Register run functions | ||||
|     engine.register_fn("run", run); | ||||
|     engine.register_fn("run_silent", run_silent); | ||||
|     engine.register_fn("run_with_options", run_with_options); | ||||
|     engine.register_fn("new_run_options", new_run_options); | ||||
|      | ||||
|     // Register process management functions | ||||
|     engine.register_fn("which", which); | ||||
|     engine.register_fn("kill", kill); | ||||
|     engine.register_fn("process_list", process_list); | ||||
|     engine.register_fn("process_get", process_get); | ||||
|      | ||||
|     Ok(()) | ||||
| } | ||||
|     // register_process_types(engine)?; // Removed | ||||
|  | ||||
| /// Register Process module types with the Rhai engine | ||||
| fn register_process_types(engine: &mut Engine) -> Result<(), Box<EvalAltResult>> { | ||||
|     // Register CommandResult type and methods | ||||
|     // Register CommandResult type and its methods | ||||
|     engine.register_type_with_name::<CommandResult>("CommandResult"); | ||||
|      | ||||
|     // Register getters for CommandResult properties | ||||
|     engine.register_get("stdout", |r: &mut CommandResult| r.stdout.clone()); | ||||
|     engine.register_get("stderr", |r: &mut CommandResult| r.stderr.clone()); | ||||
|     engine.register_get("success", |r: &mut CommandResult| r.success); | ||||
|     engine.register_get("code", |r: &mut CommandResult| r.code); | ||||
|      | ||||
|     // Register ProcessInfo type and methods | ||||
|  | ||||
|     // Register ProcessInfo type and its methods | ||||
|     engine.register_type_with_name::<ProcessInfo>("ProcessInfo"); | ||||
|      | ||||
|     // Register getters for ProcessInfo properties | ||||
|     engine.register_get("pid", |p: &mut ProcessInfo| p.pid); | ||||
|     engine.register_get("name", |p: &mut ProcessInfo| p.name.clone()); | ||||
|     engine.register_get("memory", |p: &mut ProcessInfo| p.memory); | ||||
|     engine.register_get("cpu", |p: &mut ProcessInfo| p.cpu); | ||||
|      | ||||
|  | ||||
|     // Register CommandBuilder type and its methods | ||||
|     engine.register_type_with_name::<RhaiCommandBuilder>("CommandBuilder"); | ||||
|     engine.register_fn("run", RhaiCommandBuilder::new_rhai); // This is the builder entry point | ||||
|     engine.register_fn("silent", RhaiCommandBuilder::silent); // Method on CommandBuilder | ||||
|     engine.register_fn("ignore_error", RhaiCommandBuilder::ignore_error); // Method on CommandBuilder | ||||
|     engine.register_fn("log", RhaiCommandBuilder::log); // Method on CommandBuilder | ||||
|     engine.register_fn("execute", RhaiCommandBuilder::execute_command); // Method on CommandBuilder | ||||
|  | ||||
|     // Register other process management functions | ||||
|     engine.register_fn("which", which); | ||||
|     engine.register_fn("kill", kill); | ||||
|     engine.register_fn("process_list", process_list); | ||||
|     engine.register_fn("process_get", process_get); | ||||
|  | ||||
|     Ok(()) | ||||
| } | ||||
|  | ||||
| @@ -66,6 +60,56 @@ fn run_error_to_rhai_error<T>(result: Result<T, RunError>) -> Result<T, Box<Eval | ||||
|     }) | ||||
| } | ||||
|  | ||||
| // Define a Rhai-facing builder struct | ||||
| #[derive(Clone)] | ||||
| struct RhaiCommandBuilder { | ||||
|     command: String, | ||||
|     die_on_error: bool, | ||||
|     is_silent: bool, | ||||
|     enable_log: bool, | ||||
| } | ||||
|  | ||||
| impl RhaiCommandBuilder { | ||||
|     // Constructor function for Rhai (registered as `run`) | ||||
|     pub fn new_rhai(command: &str) -> Self { | ||||
|         Self { | ||||
|             command: command.to_string(), | ||||
|             die_on_error: true, // Default: die on error | ||||
|             is_silent: false, | ||||
|             enable_log: false, | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     // Rhai method: .silent() | ||||
|     pub fn silent(mut self) -> Self { | ||||
|         self.is_silent = true; | ||||
|         self | ||||
|     } | ||||
|  | ||||
|     // Rhai method: .ignore_error() | ||||
|     pub fn ignore_error(mut self) -> Self { | ||||
|         self.die_on_error = false; | ||||
|         self | ||||
|     } | ||||
|  | ||||
|     // Rhai method: .log() | ||||
|     pub fn log(mut self) -> Self { | ||||
|         self.enable_log = true; | ||||
|         self | ||||
|     } | ||||
|  | ||||
|     // Rhai method: .execute() - Execute the command | ||||
|     pub fn execute_command(self) -> Result<CommandResult, Box<EvalAltResult>> { | ||||
|         let builder = process::run(&self.command) | ||||
|             .die(self.die_on_error) | ||||
|             .silent(self.is_silent) | ||||
|             .log(self.enable_log); | ||||
|  | ||||
|         // Execute the command | ||||
|         run_error_to_rhai_error(builder.execute()) | ||||
|     } | ||||
| } | ||||
|  | ||||
| fn process_error_to_rhai_error<T>(result: Result<T, ProcessError>) -> Result<T, Box<EvalAltResult>> { | ||||
|     result.map_err(|e| { | ||||
|         Box::new(EvalAltResult::ErrorRuntime( | ||||
| @@ -75,78 +119,6 @@ fn process_error_to_rhai_error<T>(result: Result<T, ProcessError>) -> Result<T, | ||||
|     }) | ||||
| } | ||||
|  | ||||
| /// Create a new Map with default run options | ||||
| pub fn new_run_options() -> Map { | ||||
|     let mut map = Map::new(); | ||||
|     map.insert("die".into(), Dynamic::from(true)); | ||||
|     map.insert("silent".into(), Dynamic::from(false)); | ||||
|     map.insert("async_exec".into(), Dynamic::from(false)); | ||||
|     map.insert("log".into(), Dynamic::from(false)); | ||||
|     map | ||||
| } | ||||
|  | ||||
| // | ||||
| // Run Function Wrappers | ||||
| // | ||||
|  | ||||
| /// Wrapper for process::run_command | ||||
| /// | ||||
| /// Run a command or multiline script with arguments. | ||||
| pub fn run(command: &str) -> Result<CommandResult, Box<EvalAltResult>> { | ||||
|     run_error_to_rhai_error(process::run_command(command)) | ||||
| } | ||||
|  | ||||
| /// Wrapper for process::run_silent | ||||
| /// | ||||
| /// Run a command or multiline script with arguments silently. | ||||
| pub fn run_silent(command: &str) -> Result<CommandResult, Box<EvalAltResult>> { | ||||
|     run_error_to_rhai_error(process::run_silent(command)) | ||||
| } | ||||
|  | ||||
| /// Run a command with options specified in a Map | ||||
| /// | ||||
| /// This provides a builder-style interface for Rhai scripts. | ||||
| /// | ||||
| /// # Example | ||||
| /// | ||||
| /// ```rhai | ||||
| /// let options = new_run_options(); | ||||
| /// options.die = false; | ||||
| /// options.silent = true; | ||||
| /// let result = run("echo Hello", options); | ||||
| /// ``` | ||||
| pub fn run_with_options(command: &str, options: Map) -> Result<CommandResult, Box<EvalAltResult>> { | ||||
|     let mut builder = process::run(command); | ||||
|      | ||||
|     // Apply options from the map | ||||
|     if let Some(die) = options.get("die") { | ||||
|         if let Ok(die_val) = die.clone().as_bool() { | ||||
|             builder = builder.die(die_val); | ||||
|         } | ||||
|     } | ||||
|      | ||||
|     if let Some(silent) = options.get("silent") { | ||||
|         if let Ok(silent_val) = silent.clone().as_bool() { | ||||
|             builder = builder.silent(silent_val); | ||||
|         } | ||||
|     } | ||||
|      | ||||
|     if let Some(async_exec) = options.get("async_exec") { | ||||
|         if let Ok(async_val) = async_exec.clone().as_bool() { | ||||
|             builder = builder.async_exec(async_val); | ||||
|         } | ||||
|     } | ||||
|      | ||||
|     if let Some(log) = options.get("log") { | ||||
|         if let Ok(log_val) = log.clone().as_bool() { | ||||
|             builder = builder.log(log_val); | ||||
|         } | ||||
|     } | ||||
|      | ||||
|     // Execute the command | ||||
|     run_error_to_rhai_error(builder.execute()) | ||||
| } | ||||
|  | ||||
| // | ||||
| // Process Management Function Wrappers | ||||
| // | ||||
|   | ||||
		Reference in New Issue
	
	Block a user