forked from akanyan/STARTLINER
fix: also add post scripts
This commit is contained in:
@ -255,7 +255,7 @@ impl Profile {
|
||||
|
||||
let mut game_builder;
|
||||
let mut amd_builder;
|
||||
let mut prelaunch = None;
|
||||
let mut prescript = None;
|
||||
|
||||
let target_path = PathBuf::from(&self.data.sgt.target);
|
||||
let exe_dir = target_path.parent().ok_or_else(|| anyhow!("Invalid target path"))?;
|
||||
@ -265,17 +265,6 @@ impl Profile {
|
||||
{
|
||||
game_builder = Command::new(sgt_dir.join(self.meta.game.inject_exe()));
|
||||
amd_builder = Command::new("cmd.exe");
|
||||
|
||||
let prelaunch_path = self.config_dir().join("prelaunch.bat");
|
||||
if prelaunch_path.exists() {
|
||||
let mut c = Command::new("cmd");
|
||||
c.args(["/C", "start"]);
|
||||
c.raw_arg("\"STARTLINER Prelaunch\"");
|
||||
c.args(["cmd", "/C"]);
|
||||
c.arg(prelaunch_path);
|
||||
log::debug!("Prelaunch: {:?}", c);
|
||||
prelaunch = Some(c.spawn()?);
|
||||
}
|
||||
}
|
||||
#[cfg(target_os = "linux")]
|
||||
{
|
||||
@ -284,14 +273,12 @@ impl Profile {
|
||||
|
||||
game_builder.arg(sgt_dir.join(self.meta.game.inject_exe()));
|
||||
amd_builder.arg("cmd.exe");
|
||||
}
|
||||
|
||||
let prelaunch_path = self.config_dir().join("prelaunch.sh");
|
||||
if prelaunch_path.exists() {
|
||||
prelaunch_builder = Some(Command::new("sh"));
|
||||
c.arg(prelaunch_path);
|
||||
log::debug!("Prelaunch: {:?}", c);
|
||||
prelaunch = Some(c.spawn()?);
|
||||
}
|
||||
let script_ext = if cfg!(target_os = "windows") { "bat" } else { "sh" };
|
||||
let prescript_path = self.config_dir().join(format!("pre.{script_ext}"));
|
||||
if prescript_path.exists() {
|
||||
prescript = util::spawn_script(prescript_path, &exe_dir, "\"STARTLINER launch script\"");
|
||||
}
|
||||
|
||||
amd_builder.env(
|
||||
@ -440,11 +427,11 @@ impl Profile {
|
||||
util::pkill("amdaemon.exe").await;
|
||||
}
|
||||
|
||||
if let Some(mut _child) = prelaunch {
|
||||
if let Some(mut _child) = prescript {
|
||||
#[cfg(target_os = "windows")]
|
||||
{
|
||||
// child.kill() doesn't work
|
||||
util::pkill_title("STARTLINER Prelaunch").await;
|
||||
util::pkill_title("STARTLINER launch script").await;
|
||||
}
|
||||
#[cfg(target_os = "linux")]
|
||||
{
|
||||
@ -452,6 +439,11 @@ impl Profile {
|
||||
}
|
||||
}
|
||||
|
||||
let postscript_path = self.config_dir().join(format!("post.{script_ext}"));
|
||||
if postscript_path.exists() {
|
||||
_ = util::spawn_script(postscript_path, &exe_dir, "\"STARTLINER end script\"");
|
||||
}
|
||||
|
||||
set.join_next().await.expect("No spawn").expect("No result");
|
||||
|
||||
log::debug!("Fin");
|
||||
|
@ -49,15 +49,17 @@ impl Profile {
|
||||
|
||||
{
|
||||
let sgt = &mut prf.data.sgt;
|
||||
sgt.target = PathBuf::new();
|
||||
if sgt.amfs.is_absolute() {
|
||||
sgt.amfs = PathBuf::new();
|
||||
}
|
||||
if sgt.option.is_absolute() {
|
||||
sgt.option = PathBuf::new();
|
||||
}
|
||||
if sgt.appdata.is_absolute() {
|
||||
sgt.appdata = PathBuf::new();
|
||||
if !is_diagnostic {
|
||||
sgt.target = PathBuf::new();
|
||||
if sgt.amfs.is_absolute() {
|
||||
sgt.amfs = PathBuf::new();
|
||||
}
|
||||
if sgt.option.is_absolute() {
|
||||
sgt.option = PathBuf::new();
|
||||
}
|
||||
if sgt.appdata.is_absolute() {
|
||||
sgt.appdata = PathBuf::new();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -220,4 +220,38 @@ pub fn create_shortcut(
|
||||
file.Save(Some(lnk_path.to_str().ok_or_else(|| anyhow!("Illegal shortcut path"))?), true)?;
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
pub fn spawn_script(path: impl AsRef<Path>, cwd: impl AsRef<Path>, title: &str) -> Option<tokio::process::Child> {
|
||||
// Seems? like this autism is needed to:
|
||||
// 1. pop up a cmd window
|
||||
// 2. launch the batch
|
||||
// 3. die afterwards
|
||||
let mut c;
|
||||
|
||||
#[cfg(target_os = "windows")]
|
||||
{
|
||||
c = Command::new("cmd");
|
||||
c.args(["/C", "start"]);
|
||||
c.raw_arg(title);
|
||||
c.args(["cmd", "/C"]);
|
||||
c.arg(path.as_ref());
|
||||
c.current_dir(cwd);
|
||||
}
|
||||
|
||||
#[cfg(target_os = "linux")]
|
||||
{
|
||||
c = Command::new("sh");
|
||||
c.arg(path.as_ref());
|
||||
c.current_dir(cwd);
|
||||
}
|
||||
|
||||
log::debug!("Script launch: {:?}", c);
|
||||
match c.spawn() {
|
||||
Ok(child) => Some(child),
|
||||
Err(e) => {
|
||||
log::error!("unable to launch {:?}: {e}", path.as_ref());
|
||||
None
|
||||
}
|
||||
}
|
||||
}
|
@ -1,7 +1,7 @@
|
||||
{
|
||||
"$schema": "https://schema.tauri.app/config/2",
|
||||
"productName": "STARTLINER",
|
||||
"version": "0.20.0",
|
||||
"version": "0.20.1",
|
||||
"identifier": "zip.patafour.startliner",
|
||||
"build": {
|
||||
"beforeDevCommand": "bun run dev",
|
||||
|
Reference in New Issue
Block a user