mirror of
https://github.com/pinnacle-comp/pinnacle.git
synced 2025-01-27 19:58:08 +01:00
Remove setup function
This commit is contained in:
parent
0e32f52972
commit
4e36637e19
4 changed files with 164 additions and 158 deletions
|
@ -2,7 +2,11 @@ use pinnacle_api::prelude::*;
|
|||
use pinnacle_api::*;
|
||||
|
||||
fn main() {
|
||||
pinnacle::setup(|| {
|
||||
// let mut num = 5;
|
||||
// let test = &mut num;
|
||||
|
||||
pinnacle_api::connect().unwrap();
|
||||
|
||||
let mod_key = Modifier::Ctrl;
|
||||
|
||||
let terminal = "alacritty";
|
||||
|
@ -63,6 +67,12 @@ fn main() {
|
|||
tag::get("1", Some(&output)).unwrap().toggle();
|
||||
});
|
||||
|
||||
// let mut num = 5;
|
||||
//
|
||||
// input::keybind(&[mod_key], 'm', || {
|
||||
// num += 1;
|
||||
// });
|
||||
|
||||
// let layout_cycler = tag.layout_cycler(&[
|
||||
// Layout::MasterStack,
|
||||
// Layout::Dwindle,
|
||||
|
@ -111,6 +121,6 @@ fn main() {
|
|||
},
|
||||
);
|
||||
}
|
||||
})
|
||||
.unwrap();
|
||||
|
||||
pinnacle_api::listen();
|
||||
}
|
||||
|
|
|
@ -16,8 +16,7 @@ use crate::{
|
|||
/// - `key`: The key that needs to be pressed. This takes `impl Into<KeyIntOrString>` and can
|
||||
/// take the following three types:
|
||||
/// - [`char`]: A character of the key you want. This can be `a`, `~`, `@`, and so on.
|
||||
/// - [`u32`]: The key in numeric form. You can use the keys defined in
|
||||
/// [`xkbcommon::xkb::keysyms`] for this.
|
||||
/// - [`u32`]: The key in numeric form. You can use the keys defined in [`xkbcommon::xkb::keysyms`] for this.
|
||||
/// - [`Keysym`]: The key in `Keysym` form, from [xkbcommon::xkb::Keysym].
|
||||
pub fn keybind<F>(modifiers: &[Modifier], key: impl Into<KeyIntOrString>, mut action: F)
|
||||
where
|
||||
|
|
|
@ -33,9 +33,11 @@ pub mod prelude {
|
|||
}
|
||||
|
||||
use std::{
|
||||
collections::HashMap,
|
||||
collections::{hash_map::Entry, HashMap},
|
||||
convert::Infallible,
|
||||
io::{Read, Write},
|
||||
os::unix::net::UnixStream,
|
||||
path::PathBuf,
|
||||
sync::{atomic::AtomicU32, Mutex, OnceLock},
|
||||
};
|
||||
|
||||
|
@ -134,3 +136,56 @@ fn request(request: Request) -> RequestResponse {
|
|||
|
||||
response
|
||||
}
|
||||
|
||||
/// Connect to Pinnacle. This needs to be called before you begin calling config functions.
|
||||
///
|
||||
/// This will open up a connection to the Unix socket at `$PINNACLE_SOCKET`,
|
||||
/// which should be set when you start the compositor.
|
||||
pub fn connect() -> anyhow::Result<()> {
|
||||
STREAM
|
||||
.set(Mutex::new(
|
||||
UnixStream::connect(PathBuf::from(
|
||||
std::env::var("PINNACLE_SOCKET").unwrap_or("/tmp/pinnacle_socket".to_string()),
|
||||
))
|
||||
.unwrap(),
|
||||
))
|
||||
.unwrap();
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
/// Begin listening for messages coming from Pinnacle.
|
||||
///
|
||||
/// This needs to be called at the very end of your `setup` function.
|
||||
pub fn listen() -> Infallible {
|
||||
loop {
|
||||
let mut unread_callback_msgs = UNREAD_CALLBACK_MSGS.lock().unwrap();
|
||||
|
||||
for cb_id in unread_callback_msgs.keys().copied().collect::<Vec<_>>() {
|
||||
let Entry::Occupied(entry) = unread_callback_msgs.entry(cb_id) else {
|
||||
unreachable!();
|
||||
};
|
||||
let IncomingMsg::CallCallback { callback_id, args } = entry.remove() else {
|
||||
unreachable!();
|
||||
};
|
||||
let mut callback_vec = CALLBACK_VEC.lock().unwrap();
|
||||
let Some(callback) = callback_vec.get_mut(callback_id.0 as usize) else {
|
||||
unreachable!();
|
||||
};
|
||||
callback(args);
|
||||
}
|
||||
|
||||
let incoming_msg = read_msg(None);
|
||||
|
||||
let IncomingMsg::CallCallback { callback_id, args } = incoming_msg else {
|
||||
unreachable!();
|
||||
};
|
||||
|
||||
let mut callback_vec = CALLBACK_VEC.lock().unwrap();
|
||||
let Some(callback) = callback_vec.get_mut(callback_id.0 as usize) else {
|
||||
unreachable!();
|
||||
};
|
||||
|
||||
callback(args);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,66 +1,8 @@
|
|||
//! Functions for compositor control, like `setup` and `quit`.
|
||||
|
||||
use std::{
|
||||
collections::hash_map::Entry, convert::Infallible, os::unix::net::UnixStream, path::PathBuf,
|
||||
sync::Mutex,
|
||||
};
|
||||
|
||||
use crate::{
|
||||
msg::{IncomingMsg, Msg},
|
||||
read_msg, send_msg, CALLBACK_VEC, STREAM, UNREAD_CALLBACK_MSGS,
|
||||
};
|
||||
use crate::{msg::Msg, send_msg};
|
||||
|
||||
/// Quit Pinnacle.
|
||||
pub fn quit() {
|
||||
send_msg(Msg::Quit).unwrap();
|
||||
}
|
||||
|
||||
/// Setup Pinnacle.
|
||||
///
|
||||
/// This will attempt to connect to the socket at `$PINNACLE_SOCKET`, which should be set by the
|
||||
/// compositor when opened.
|
||||
///
|
||||
/// It will then run your `config_func`.
|
||||
///
|
||||
/// Lastly, it will enter a loop to listen to messages coming from Pinnacle.
|
||||
///
|
||||
/// If this function returns, an error has occurred.
|
||||
pub fn setup(config_func: impl FnOnce()) -> anyhow::Result<Infallible> {
|
||||
STREAM
|
||||
.set(Mutex::new(UnixStream::connect(PathBuf::from(
|
||||
std::env::var("PINNACLE_SOCKET").unwrap_or("/tmp/pinnacle_socket".to_string()),
|
||||
))?))
|
||||
.unwrap();
|
||||
|
||||
config_func();
|
||||
|
||||
loop {
|
||||
let mut unread_callback_msgs = UNREAD_CALLBACK_MSGS.lock().unwrap();
|
||||
let mut callback_vec = CALLBACK_VEC.lock().unwrap();
|
||||
|
||||
for cb_id in unread_callback_msgs.keys().copied().collect::<Vec<_>>() {
|
||||
let Entry::Occupied(entry) = unread_callback_msgs.entry(cb_id) else {
|
||||
unreachable!();
|
||||
};
|
||||
let IncomingMsg::CallCallback { callback_id, args } = entry.remove() else {
|
||||
unreachable!();
|
||||
};
|
||||
let Some(callback) = callback_vec.get_mut(callback_id.0 as usize) else {
|
||||
unreachable!();
|
||||
};
|
||||
callback(args);
|
||||
}
|
||||
|
||||
let incoming_msg = read_msg(None);
|
||||
|
||||
let IncomingMsg::CallCallback { callback_id, args } = incoming_msg else {
|
||||
unreachable!();
|
||||
};
|
||||
|
||||
let Some(callback) = callback_vec.get_mut(callback_id.0 as usize) else {
|
||||
unreachable!();
|
||||
};
|
||||
|
||||
callback(args);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue