diff --git a/README.md b/README.md index 86fc77b..2165d9c 100644 --- a/README.md +++ b/README.md @@ -36,6 +36,12 @@ A window manager/compositor agnostic settings application for Linux written in r ReSet features a plugin system by loading dynamic libraries for both the daemon and the ReSet graphical user interface. A list of official plugins, installation guides and their documentation can be found at [ReSet-Plugins](https://github.com/Xetibo/ReSet-Plugins). +### Installation + +Plugins are loaded either from `/usr/lib/reset` or `~/.config/reset/plugins`. In order to install the plugin, either install a distribution specific package that places the library into the specified system folder, or place the library in the plugins folder in your config directory. + +Note, after installation, please move to confirmation. + ### Confirmation In order for your plugins to load, you have to define them in `.config/reset/ReSet.toml`. diff --git a/src/components/utils.rs b/src/components/utils.rs index 11d0894..1b4bdd5 100644 --- a/src/components/utils.rs +++ b/src/components/utils.rs @@ -10,6 +10,9 @@ use glib::prelude::Cast; use glib::Object; use gtk::prelude::{GObjectPropertyExpressionExt, ListBoxRowExt, ListItemExt, WidgetExt}; use gtk::{Align, SignalListItemFactory, StringObject}; +use re_set_lib::ERROR; +#[cfg(debug_assertions)] +use re_set_lib::{utils::macros::ErrorLevel, write_log_to_file}; pub const DBUS_PATH: &str = "/org/Xetibo/ReSet/Daemon"; pub const WIRELESS: &str = "org.Xetibo.ReSet.Network"; @@ -93,5 +96,12 @@ pub fn get_capabilities() -> Vec { let conn = Connection::new_session().unwrap(); let proxy = conn.with_proxy(BASE, DBUS_PATH, Duration::from_millis(10000)); let res: Result<(Vec,), Error> = proxy.method_call(BASE, "GetCapabilities", ()); + if res.is_err() { + ERROR!( + "Could not call capabilities from daemon", + ErrorLevel::Critical + ); + return Vec::new(); + } res.unwrap().0 } diff --git a/src/main.rs b/src/main.rs index d1f6f63..c78b505 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,5 +1,5 @@ use std::hint::{self}; -use std::sync::atomic::AtomicBool; +use std::sync::atomic::{AtomicBool, Ordering}; use std::sync::Arc; use std::thread; use std::time::Duration; @@ -81,5 +81,7 @@ async fn daemon_check(ready: Arc) { let res = handle.join(); if res.unwrap().is_err() { run_daemon(Some(ready)).await; + } else { + ready.store(true, Ordering::SeqCst); } }