Use Server enum instead of Option to match compositor

This commit is contained in:
cyber-sushi 2024-05-18 01:47:49 +02:00
parent c19357d0b8
commit 31c1b1ce44

View file

@ -1,23 +1,26 @@
use crate::Config;
use crate::udev_monitor::{Client, Server};
use serde_json;
use swayipc_async::Connection;
use std::{collections::HashMap, process::Command};
use x11rb::protocol::xproto::{get_property, get_input_focus, Atom, AtomEnum};
pub async fn get_active_window(current_desktop: &Option<String>, config: &HashMap<String, Config>) -> String {
let active_client = current_desktop.clone().unwrap_or(String::from("default"));
match active_client.as_str() {
pub async fn get_active_window(server: &Server, config: &HashMap<Client, Config>) -> Client {
match server {
Server::Connected(server) => {
let server_str = server.as_str();
match server_str {
"Hyprland" => {
let query = Command::new("hyprctl").args(["activewindow", "-j"]).output().unwrap();
if let Ok(reply) = serde_json::from_str::<serde_json::Value>(std::str::from_utf8(query.stdout.as_slice()).unwrap()) {
let active_window = reply["class"].to_string().replace("\"", "");
let active_window = Client::Class(reply["class"].to_string().replace("\"", ""));
if config.contains_key(&active_window) {
active_window
} else {
String::from("default")
Client::Default
}
} else {
String::from("default")
Client::Default
}
},
"sway" => {
@ -25,16 +28,16 @@ pub async fn get_active_window(current_desktop: &Option<String>, config: &HashMa
let active_window = match connection.get_tree().await.unwrap().find_focused(|window| window.focused) {
Some(window) => {
match window.app_id {
Some(id) => id,
None => window.window_properties.unwrap().class.unwrap()
Some(id) => Client::Class(id),
None => Client::Class(window.window_properties.unwrap().class.unwrap())
}
},
None => String::from("default")
None => Client::Default
};
if config.contains_key(&active_window) {
active_window
} else {
String::from("default")
Client::Default
}
},
"x11" => {
@ -50,17 +53,21 @@ pub async fn get_active_window(current_desktop: &Option<String>, config: &HashMa
if class.last() == Some(&0) {
class = &class[..class.len() -1];
}
let active_window = std::str::from_utf8(class).unwrap().to_string();
let active_window = Client::Class(std::str::from_utf8(class).unwrap().to_string());
if config.contains_key(&active_window) {
active_window
} else {
String::from("default")
Client::Default
}
} else {
String::from("default")
Client::Default
}
},
_ => String::from("default")
_ => Client::Default
}
},
Server::Unsupported => Client::Default,
Server::Failed => Client::Default,
}
}