You've already forked AstralRinth
forked from didirus/AstralRinth
* child process api * added hook to js * process API + restructured process state storage * formatting * added path-pid check and fixed probs * prettier * added profile checking function --------- Co-authored-by: Wyatt <wyatt@modrinth.com>
73 lines
2.1 KiB
Rust
73 lines
2.1 KiB
Rust
use std::path::{Path, PathBuf};
|
|
|
|
use crate::api::Result;
|
|
use theseus::prelude::*;
|
|
|
|
// Checks if a process has finished by process PID
|
|
#[tauri::command]
|
|
pub async fn process_has_finished_by_pid(pid: u32) -> Result<bool> {
|
|
Ok(process::has_finished_by_pid(pid).await?)
|
|
}
|
|
|
|
// Gets process exit status by process PID
|
|
#[tauri::command]
|
|
pub async fn process_get_exit_status_by_pid(pid: u32) -> Result<Option<i32>> {
|
|
Ok(process::get_exit_status_by_pid(pid).await?)
|
|
}
|
|
|
|
// Gets all process PIDs
|
|
#[tauri::command]
|
|
pub async fn process_get_all_pids() -> Result<Vec<u32>> {
|
|
Ok(process::get_all_pids().await?)
|
|
}
|
|
|
|
// Gets all running process PIDs
|
|
#[tauri::command]
|
|
pub async fn process_get_all_running_pids() -> Result<Vec<u32>> {
|
|
Ok(process::get_all_running_pids().await?)
|
|
}
|
|
|
|
// Gets all process PIDs by profile path
|
|
#[tauri::command]
|
|
pub async fn process_get_pids_by_profile_path(
|
|
profile_path: &Path,
|
|
) -> Result<Vec<u32>> {
|
|
Ok(process::get_pids_by_profile_path(profile_path).await?)
|
|
}
|
|
|
|
// Gets the Profile paths of each *running* stored process in the state
|
|
#[tauri::command]
|
|
pub async fn process_get_all_running_profile_paths() -> Result<Vec<PathBuf>> {
|
|
Ok(process::get_all_running_profile_paths().await?)
|
|
}
|
|
|
|
// Gets the Profiles (cloned) of each *running* stored process in the state
|
|
#[tauri::command]
|
|
pub async fn process_get_all_running_profiles() -> Result<Vec<Profile>> {
|
|
Ok(process::get_all_running_profiles().await?)
|
|
}
|
|
|
|
// Gets process stderr by process PID
|
|
#[tauri::command]
|
|
pub async fn process_get_stderr_by_pid(pid: u32) -> Result<String> {
|
|
Ok(process::get_stderr_by_pid(pid).await?)
|
|
}
|
|
|
|
// Gets process stdout by process PID
|
|
#[tauri::command]
|
|
pub async fn process_get_stdout_by_pid(pid: u32) -> Result<String> {
|
|
Ok(process::get_stdout_by_pid(pid).await?)
|
|
}
|
|
|
|
// Kill a process by process PID
|
|
#[tauri::command]
|
|
pub async fn process_kill_by_pid(pid: u32) -> Result<()> {
|
|
Ok(process::kill_by_pid(pid).await?)
|
|
}
|
|
|
|
// Wait for a process to finish by process PID
|
|
#[tauri::command]
|
|
pub async fn process_wait_for_by_pid(pid: u32) -> Result<()> {
|
|
Ok(process::wait_for_by_pid(pid).await?)
|
|
}
|