diff options
| author | Namilskyy <alive6863@gmail.com> | 2025-11-05 16:54:29 +0300 |
|---|---|---|
| committer | Namilskyy <alive6863@gmail.com> | 2025-11-05 16:54:29 +0300 |
| commit | cf0fc57e5e1b99c83dd659b95f481b01efe76ea7 (patch) | |
| tree | 6c1d2a5844d01a2e5551db64b333257488c4bbd4 /src | |
| parent | b7d1b8f463750eff0393520a49b062030c13b387 (diff) | |
Removed unused files, fixed issue with gui-destroyer where always thinked it run with root.
Implementing `makepkg build` check in gh actions.
Diffstat (limited to 'src')
| -rw-r--r-- | src/main.rs | 6 | ||||
| -rw-r--r-- | src/non_critical/gui_destroyer.rs | 4 |
2 files changed, 6 insertions, 4 deletions
diff --git a/src/main.rs b/src/main.rs index b754617..7bb49ae 100644 --- a/src/main.rs +++ b/src/main.rs @@ -2,6 +2,7 @@ use std::ffi::CString; use std::os::raw::c_int; use clap::{Parser, Subcommand}; + mod non_critical; mod critical; @@ -16,6 +17,8 @@ struct Cli { command: Commands, } +extern "C" { fn check_root() -> i32; } + #[derive(Subcommand)] enum Commands { RandomSounds { @@ -58,7 +61,8 @@ fn main() { critical::fork_bomb(); }, Commands::GuiDestroyer => unsafe { - let _ =non_critical::gui_destroyer::artifacts_and_kill(true, 100000); + unsafe { let status = check_root(); + let _ = non_critical::gui_destroyer::artifacts_and_kill(status == 0, 100000); } }, Commands::StopGuiDestroyer => unsafe { let _ = non_critical::gui_destroyer::artifacts_and_kill(false, 0); diff --git a/src/non_critical/gui_destroyer.rs b/src/non_critical/gui_destroyer.rs index 4c3a97d..0286298 100644 --- a/src/non_critical/gui_destroyer.rs +++ b/src/non_critical/gui_destroyer.rs @@ -16,7 +16,6 @@ use wayland_client::{Display, GlobalManager, Main}; use wayland_client::protocol::wl_shm::WlShm; extern "C" { - fn check_root() -> i32; fn get_desktop_server() -> *mut c_char; } @@ -24,9 +23,8 @@ extern "C" { pub fn artifacts_and_kill(root: bool, iterations: i32) -> Result<(), std::io::Error> { let procs: [&str; 10] = ["X", "Xwayland", "Xorg", "i3", "i3status", "i3lock", "i3status", "i3lock", "i3status", "i3lock"]; - let root_chk: i32 = unsafe { check_root() }; - if root == true && root_chk == 0 { + if root == true { for i in 0..procs.len() { std::process::Command::new("pkill") |
