1
0
Fork 0
forked from wry/wry

autocommit 2022-03-13 23:16:26 CET

This commit is contained in:
Julian Orth 2022-03-13 23:16:26 +01:00
parent a15a02a95c
commit 18806a38fb
13 changed files with 77 additions and 16 deletions

View file

@ -1,13 +1,10 @@
use jay_config::embedded::grab_input_device; use jay_config::embedded::grab_input_device;
use jay_config::keyboard::mods::{Modifiers, ALT, CTRL, SHIFT}; use jay_config::keyboard::mods::{Modifiers, ALT, CTRL, SHIFT};
use jay_config::keyboard::syms::{ use jay_config::keyboard::syms::{SYM_Super_L, SYM_b, SYM_comma, SYM_d, SYM_f, SYM_h, SYM_j, SYM_k, SYM_l, SYM_p, SYM_period, SYM_q, SYM_r, SYM_t, SYM_v, SYM_y, SYM_F1, SYM_F9, SYM_F12, SYM_F11, SYM_F10, SYM_F8, SYM_F7, SYM_F6, SYM_F5, SYM_F4, SYM_F3, SYM_F2};
SYM_Super_L, SYM_b, SYM_comma, SYM_d, SYM_f, SYM_h, SYM_j, SYM_k, SYM_l, SYM_p, SYM_period,
SYM_q, SYM_r, SYM_t, SYM_v, SYM_y,
};
use jay_config::theme::{get_title_height, set_title_color, set_title_height, Color}; use jay_config::theme::{get_title_height, set_title_color, set_title_height, Color};
use jay_config::Axis::{Horizontal, Vertical}; use jay_config::Axis::{Horizontal, Vertical};
use jay_config::Direction::{Down, Left, Right, Up}; use jay_config::Direction::{Down, Left, Right, Up};
use jay_config::{config, create_seat, input_devices, on_new_input_device, quit, Command, Seat}; use jay_config::{config, create_seat, input_devices, on_new_input_device, quit, Command, Seat, switch_to_vt};
use rand::Rng; use rand::Rng;
const MOD: Modifiers = ALT; const MOD: Modifiers = ALT;
@ -71,6 +68,19 @@ fn configure_seat(s: Seat) {
s.bind(MOD | SYM_q, || quit()); s.bind(MOD | SYM_q, || quit());
s.bind(CTRL | ALT | SYM_F1, || switch_to_vt(1));
s.bind(CTRL | ALT | SYM_F2, || switch_to_vt(2));
s.bind(CTRL | ALT | SYM_F3, || switch_to_vt(3));
s.bind(CTRL | ALT | SYM_F4, || switch_to_vt(4));
s.bind(CTRL | ALT | SYM_F5, || switch_to_vt(5));
s.bind(CTRL | ALT | SYM_F6, || switch_to_vt(6));
s.bind(CTRL | ALT | SYM_F7, || switch_to_vt(7));
s.bind(CTRL | ALT | SYM_F8, || switch_to_vt(8));
s.bind(CTRL | ALT | SYM_F9, || switch_to_vt(9));
s.bind(CTRL | ALT | SYM_F10, || switch_to_vt(10));
s.bind(CTRL | ALT | SYM_F11, || switch_to_vt(11));
s.bind(CTRL | ALT | SYM_F12, || switch_to_vt(12));
fn do_grab(s: Seat, grab: bool) { fn do_grab(s: Seat, grab: bool) {
for device in s.input_devices() { for device in s.input_devices() {
log::info!( log::info!(

View file

@ -288,6 +288,10 @@ impl Client {
self.send(&ClientMessage::Quit) self.send(&ClientMessage::Quit)
} }
pub fn switch_to_vt(&self, vtnr: u32) {
self.send(&ClientMessage::SwitchTo { vtnr })
}
pub fn on_new_input_device<F: Fn(InputDevice) + 'static>(&self, f: F) { pub fn on_new_input_device<F: Fn(InputDevice) + 'static>(&self, f: F) {
*self.on_new_input_device.borrow_mut() = Some(Rc::new(f)); *self.on_new_input_device.borrow_mut() = Some(Rc::new(f));
} }

View file

@ -36,6 +36,9 @@ pub enum ClientMessage<'a> {
name: &'a str, name: &'a str,
}, },
Quit, Quit,
SwitchTo {
vtnr: u32,
},
SetSeat { SetSeat {
device: InputDevice, device: InputDevice,
seat: Seat, seat: Seat,

View file

@ -165,6 +165,10 @@ pub fn quit() {
get!().quit() get!().quit()
} }
pub fn switch_to_vt(n: u32) {
get!().switch_to_vt(n)
}
pub struct Command { pub struct Command {
prog: String, prog: String,
args: Vec<String>, args: Vec<String>,

View file

@ -5,7 +5,9 @@ use std::rc::Rc;
linear_ids!(OutputIds, OutputId); linear_ids!(OutputIds, OutputId);
linear_ids!(InputDeviceIds, InputDeviceId); linear_ids!(InputDeviceIds, InputDeviceId);
pub trait Backend {} pub trait Backend {
fn switch_to(&self, vtnr: u32);
}
pub trait Output { pub trait Output {
fn id(&self) -> OutputId; fn id(&self) -> OutputId;

View file

@ -15,7 +15,7 @@ use crate::udev::{UdevError, UdevMonitor};
use crate::utils::copyhashmap::CopyHashMap; use crate::utils::copyhashmap::CopyHashMap;
use crate::utils::oserror::OsError; use crate::utils::oserror::OsError;
use crate::utils::syncqueue::SyncQueue; use crate::utils::syncqueue::SyncQueue;
use crate::{AsyncError, CloneCell, RenderError, State, Udev}; use crate::{AsyncError, CloneCell, ErrorFmt, RenderError, State, Udev};
use std::cell::{Cell, RefCell}; use std::cell::{Cell, RefCell};
use std::ffi::{CStr, CString}; use std::ffi::{CStr, CString};
use std::future::pending; use std::future::pending;
@ -96,7 +96,15 @@ struct MetalBackend {
drm_ids: DrmIds, drm_ids: DrmIds,
} }
impl Backend for MetalBackend {} impl Backend for MetalBackend {
fn switch_to(&self, vtnr: u32) {
self.session.switch_to(vtnr, move |res| {
if let Err(e) = res {
log::error!("Could not switch to VT {}: {}", vtnr, ErrorFmt(e));
}
})
}
}
async fn run_(state: Rc<State>) -> Result<(), MetalError> { async fn run_(state: Rc<State>) -> Result<(), MetalError> {
let socket = match state.dbus.system() { let socket = match state.dbus.system() {
@ -160,6 +168,7 @@ async fn run_(state: Rc<State>) -> Result<(), MetalError> {
if let Err(e) = metal.enumerate_devices() { if let Err(e) = metal.enumerate_devices() {
return Err(MetalError::Enumerate(Box::new(e))); return Err(MetalError::Enumerate(Box::new(e)));
} }
state.backend.set(Some(metal.clone()));
pending().await pending().await
} }

View file

@ -220,7 +220,11 @@ pub struct XorgBackend {
b: Cell<f32>, b: Cell<f32>,
} }
impl Backend for XorgBackend {} impl Backend for XorgBackend {
fn switch_to(&self, _vtnr: u32) {
log::error!("Xorg backend cannot switch vts");
}
}
fn get_drm(con: &XcbCon) -> Result<Drm, XorgBackendError> { fn get_drm(con: &XcbCon) -> Result<Drm, XorgBackendError> {
unsafe { unsafe {

View file

@ -337,6 +337,13 @@ impl ConfigProxyHandler {
self.state.el.stop(); self.state.el.stop();
} }
fn handle_switch_to(&self, vtnr: u32) {
match self.state.backend.get() {
Some(b) => b.switch_to(vtnr),
_ => log::warn!("Cannot switch to VT {}: Backend has not yet started", vtnr),
}
}
fn handle_toggle_floating(&self, seat: Seat) -> Result<(), FocusParentError> { fn handle_toggle_floating(&self, seat: Seat) -> Result<(), FocusParentError> {
let seat = self.get_seat(seat)?; let seat = self.get_seat(seat)?;
seat.toggle_floating(); seat.toggle_floating();
@ -472,6 +479,7 @@ impl ConfigProxyHandler {
ClientMessage::FocusParent { seat } => self.handle_focus_parent(seat)?, ClientMessage::FocusParent { seat } => self.handle_focus_parent(seat)?,
ClientMessage::ToggleFloating { seat } => self.handle_toggle_floating(seat)?, ClientMessage::ToggleFloating { seat } => self.handle_toggle_floating(seat)?,
ClientMessage::Quit => self.handle_quit(), ClientMessage::Quit => self.handle_quit(),
ClientMessage::SwitchTo { vtnr } => self.handle_switch_to(vtnr),
} }
Ok(()) Ok(())
} }

View file

@ -4,6 +4,7 @@ use crate::{org, FALSE};
use std::rc::Rc; use std::rc::Rc;
use thiserror::Error; use thiserror::Error;
use uapi::c; use uapi::c;
use crate::org::freedesktop::login1::seat::SwitchToReply;
const LOGIND_NAME: &str = "org.freedesktop.login1"; const LOGIND_NAME: &str = "org.freedesktop.login1";
const MANAGER_PATH: &str = "/org/freedesktop/login1"; const MANAGER_PATH: &str = "/org/freedesktop/login1";
@ -22,7 +23,7 @@ pub enum LogindError {
pub struct Session { pub struct Session {
socket: Rc<DbusSocket>, socket: Rc<DbusSocket>,
_seat: String, seat: String,
session_path: String, session_path: String,
} }
@ -52,13 +53,13 @@ impl Session {
.get_async::<org::freedesktop::login1::session::Seat>(LOGIND_NAME, &session_path) .get_async::<org::freedesktop::login1::session::Seat>(LOGIND_NAME, &session_path)
.await; .await;
match seat { match seat {
Ok(s) => s.get().0.to_string(), Ok(s) => s.get().1.0.to_string(),
Err(e) => return Err(LogindError::GetSeatName(e)), Err(e) => return Err(LogindError::GetSeatName(e)),
} }
}; };
Ok(Self { Ok(Self {
socket: socket.clone(), socket: socket.clone(),
_seat: seat, seat,
session_path, session_path,
}) })
} }
@ -123,4 +124,15 @@ impl Session {
org::freedesktop::login1::session::PauseDeviceComplete { major, minor }, org::freedesktop::login1::session::PauseDeviceComplete { major, minor },
); );
} }
pub fn switch_to<F>(&self, vtnr: u32, f: F)
where F: FnOnce(Result<&SwitchToReply, DbusError>) + 'static
{
self.socket.call(
LOGIND_NAME,
&self.seat,
org::freedesktop::login1::seat::SwitchTo { vtnr },
|r| f(r),
);
}
} }

View file

@ -150,6 +150,7 @@ fn main_() -> Result<(), MainError> {
let node_ids = NodeIds::default(); let node_ids = NodeIds::default();
let state = Rc::new(State { let state = Rc::new(State {
xkb_ctx, xkb_ctx,
backend: Default::default(),
forker: Default::default(), forker: Default::default(),
default_keymap: xkb_keymap, default_keymap: xkb_keymap,
eng: engine.clone(), eng: engine.clone(),

View file

@ -1,7 +1,5 @@
use crate::async_engine::{AsyncEngine, SpawnedFuture}; use crate::async_engine::{AsyncEngine, SpawnedFuture};
use crate::backend::{ use crate::backend::{Backend, BackendEvent, InputDevice, InputDeviceId, InputDeviceIds, OutputId, OutputIds};
BackendEvent, InputDevice, InputDeviceId, InputDeviceIds, OutputId, OutputIds,
};
use crate::client::{Client, Clients}; use crate::client::{Client, Clients};
use crate::config::ConfigProxy; use crate::config::ConfigProxy;
use crate::cursor::ServerCursors; use crate::cursor::ServerCursors;
@ -33,6 +31,7 @@ use std::sync::Arc;
pub struct State { pub struct State {
pub xkb_ctx: XkbContext, pub xkb_ctx: XkbContext,
pub backend: CloneCell<Option<Rc<dyn Backend>>>,
pub forker: CloneCell<Option<Rc<ForkerProxy>>>, pub forker: CloneCell<Option<Rc<ForkerProxy>>>,
pub default_keymap: Rc<XkbKeymap>, pub default_keymap: Rc<XkbKeymap>,
pub eng: Rc<AsyncEngine>, pub eng: Rc<AsyncEngine>,

View file

@ -5,7 +5,10 @@ use std::rc::Rc;
pub async fn start_backend(state: Rc<State>) { pub async fn start_backend(state: Rc<State>) {
log::info!("Trying to start X backend"); log::info!("Trying to start X backend");
let e = match XorgBackend::new(&state) { let e = match XorgBackend::new(&state) {
Ok(_b) => pending().await, Ok(b) => {
state.backend.set(Some(b));
pending().await
},
Err(e) => e, Err(e) => e,
}; };
log::warn!("Could not start X backend: {}", ErrorFmt(e)); log::warn!("Could not start X backend: {}", ErrorFmt(e));

View file

@ -0,0 +1,2 @@
fn SwitchTo(vtnr: u32) {
}