config: add Seat.get_keyboard_output and Connector.workspaces
This commit is contained in:
parent
b83bf0657b
commit
00735e4621
7 changed files with 127 additions and 30 deletions
|
|
@ -417,6 +417,12 @@ impl Client {
|
||||||
workspace
|
workspace
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn get_seat_keyboard_workspace(&self, seat: Seat) -> Workspace {
|
||||||
|
let res = self.send_with_response(&ClientMessage::GetSeatKeyboardWorkspace { seat });
|
||||||
|
get_response!(res, Workspace(0), GetSeatKeyboardWorkspace { workspace });
|
||||||
|
workspace
|
||||||
|
}
|
||||||
|
|
||||||
pub fn set_default_workspace_capture(&self, capture: bool) {
|
pub fn set_default_workspace_capture(&self, capture: bool) {
|
||||||
self.send(&ClientMessage::SetDefaultWorkspaceCapture { capture });
|
self.send(&ClientMessage::SetDefaultWorkspaceCapture { capture });
|
||||||
}
|
}
|
||||||
|
|
@ -1076,6 +1082,19 @@ impl Client {
|
||||||
self.send(&ClientMessage::SetEiSocketEnabled { enabled })
|
self.send(&ClientMessage::SetEiSocketEnabled { enabled })
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn get_connector_active_workspace(&self, connector: Connector) -> Workspace {
|
||||||
|
let res =
|
||||||
|
self.send_with_response(&ClientMessage::GetConnectorActiveWorkspace { connector });
|
||||||
|
get_response!(res, Workspace(0), GetConnectorActiveWorkspace { workspace });
|
||||||
|
workspace
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn get_connector_workspaces(&self, connector: Connector) -> Vec<Workspace> {
|
||||||
|
let res = self.send_with_response(&ClientMessage::GetConnectorWorkspaces { connector });
|
||||||
|
get_response!(res, vec![], GetConnectorWorkspaces { workspaces });
|
||||||
|
workspaces
|
||||||
|
}
|
||||||
|
|
||||||
pub fn latch<F: FnOnce() + 'static>(&self, seat: Seat, f: F) {
|
pub fn latch<F: FnOnce() + 'static>(&self, seat: Seat, f: F) {
|
||||||
if !self.feat_mod_mask.get() {
|
if !self.feat_mod_mask.get() {
|
||||||
log::error!("compositor does not support latching");
|
log::error!("compositor does not support latching");
|
||||||
|
|
|
||||||
|
|
@ -556,6 +556,15 @@ pub enum ClientMessage<'a> {
|
||||||
SetShowFloatPinIcon {
|
SetShowFloatPinIcon {
|
||||||
show: bool,
|
show: bool,
|
||||||
},
|
},
|
||||||
|
GetSeatKeyboardWorkspace {
|
||||||
|
seat: Seat,
|
||||||
|
},
|
||||||
|
GetConnectorActiveWorkspace {
|
||||||
|
connector: Connector,
|
||||||
|
},
|
||||||
|
GetConnectorWorkspaces {
|
||||||
|
connector: Connector,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize, Debug)]
|
#[derive(Serialize, Deserialize, Debug)]
|
||||||
|
|
@ -710,6 +719,15 @@ pub enum Response {
|
||||||
GetFloatPinned {
|
GetFloatPinned {
|
||||||
pinned: bool,
|
pinned: bool,
|
||||||
},
|
},
|
||||||
|
GetSeatKeyboardWorkspace {
|
||||||
|
workspace: Workspace,
|
||||||
|
},
|
||||||
|
GetConnectorActiveWorkspace {
|
||||||
|
workspace: Workspace,
|
||||||
|
},
|
||||||
|
GetConnectorWorkspaces {
|
||||||
|
workspaces: Vec<Workspace>,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize, Debug)]
|
#[derive(Serialize, Deserialize, Debug)]
|
||||||
|
|
|
||||||
|
|
@ -359,6 +359,14 @@ impl Seat {
|
||||||
get!(Workspace(0)).get_seat_workspace(self)
|
get!(Workspace(0)).get_seat_workspace(self)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Returns the workspace that is currently active on the output that contains the seat's
|
||||||
|
/// keyboard focus.
|
||||||
|
///
|
||||||
|
/// If no such workspace exists, `exists` returns `false` for the returned workspace.
|
||||||
|
pub fn get_keyboard_workspace(self) -> Workspace {
|
||||||
|
get!(Workspace(0)).get_seat_keyboard_workspace(self)
|
||||||
|
}
|
||||||
|
|
||||||
/// Shows the workspace and sets the keyboard focus of the seat to that workspace.
|
/// Shows the workspace and sets the keyboard focus of the seat to that workspace.
|
||||||
///
|
///
|
||||||
/// If the workspace doesn't currently exist, it is created on the output that contains the
|
/// If the workspace doesn't currently exist, it is created on the output that contains the
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,7 @@
|
||||||
use {
|
use {
|
||||||
crate::{
|
crate::{
|
||||||
_private::WireMode,
|
_private::WireMode,
|
||||||
PciId,
|
PciId, Workspace,
|
||||||
video::connector_type::{
|
video::connector_type::{
|
||||||
CON_9PIN_DIN, CON_COMPONENT, CON_COMPOSITE, CON_DISPLAY_PORT, CON_DPI, CON_DSI,
|
CON_9PIN_DIN, CON_COMPONENT, CON_COMPOSITE, CON_DISPLAY_PORT, CON_DPI, CON_DSI,
|
||||||
CON_DVIA, CON_DVID, CON_DVII, CON_EDP, CON_EMBEDDED_WINDOW, CON_HDMIA, CON_HDMIB,
|
CON_DVIA, CON_DVID, CON_DVII, CON_EDP, CON_EMBEDDED_WINDOW, CON_HDMIA, CON_HDMIB,
|
||||||
|
|
@ -301,6 +301,21 @@ impl Connector {
|
||||||
pub fn set_brightness(self, brightness: Option<f64>) {
|
pub fn set_brightness(self, brightness: Option<f64>) {
|
||||||
get!().connector_set_brightness(self, brightness);
|
get!().connector_set_brightness(self, brightness);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Get the currently visible/active workspace.
|
||||||
|
///
|
||||||
|
/// If this connector is not connected, or is there no active workspace, returns a
|
||||||
|
/// workspace whose `exists()` returns false.
|
||||||
|
pub fn active_workspace(self) -> Workspace {
|
||||||
|
get!(Workspace(0)).get_connector_active_workspace(self)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Get all workspaces on this connector.
|
||||||
|
///
|
||||||
|
/// If this connector is not connected, returns an empty list.
|
||||||
|
pub fn workspaces(self) -> Vec<Workspace> {
|
||||||
|
get!().get_connector_workspaces(self)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns all available DRM devices.
|
/// Returns all available DRM devices.
|
||||||
|
|
|
||||||
|
|
@ -137,6 +137,20 @@ impl ConfigProxyHandler {
|
||||||
self.next_id.fetch_add(1)
|
self.next_id.fetch_add(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn get_workspace_by_name(&self, name: &String) -> Workspace {
|
||||||
|
let id = match self.workspaces_by_name.get(name) {
|
||||||
|
None => {
|
||||||
|
let id = self.workspace_ids.fetch_add(1);
|
||||||
|
let name = Rc::new(name.clone());
|
||||||
|
self.workspaces_by_name.set(name.clone(), id);
|
||||||
|
self.workspaces_by_id.set(id, name);
|
||||||
|
id
|
||||||
|
}
|
||||||
|
Some(id) => id,
|
||||||
|
};
|
||||||
|
Workspace(id)
|
||||||
|
}
|
||||||
|
|
||||||
fn handle_log_request(
|
fn handle_log_request(
|
||||||
&self,
|
&self,
|
||||||
level: LogLevel,
|
level: LogLevel,
|
||||||
|
|
@ -410,17 +424,7 @@ impl ConfigProxyHandler {
|
||||||
fn handle_get_workspaces(&self) {
|
fn handle_get_workspaces(&self) {
|
||||||
let mut workspaces = vec![];
|
let mut workspaces = vec![];
|
||||||
for ws in self.state.workspaces.lock().values() {
|
for ws in self.state.workspaces.lock().values() {
|
||||||
let id = match self.workspaces_by_name.get(&ws.name) {
|
workspaces.push(self.get_workspace_by_name(&ws.name));
|
||||||
None => {
|
|
||||||
let id = self.workspace_ids.fetch_add(1);
|
|
||||||
let name = Rc::new(ws.name.clone());
|
|
||||||
self.workspaces_by_name.set(name.clone(), id);
|
|
||||||
self.workspaces_by_id.set(id, name);
|
|
||||||
id
|
|
||||||
}
|
|
||||||
Some(id) => id,
|
|
||||||
};
|
|
||||||
workspaces.push(Workspace(id));
|
|
||||||
}
|
}
|
||||||
self.respond(Response::GetWorkspaces { workspaces });
|
self.respond(Response::GetWorkspaces { workspaces });
|
||||||
}
|
}
|
||||||
|
|
@ -708,18 +712,8 @@ impl ConfigProxyHandler {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn handle_get_workspace(&self, name: &str) {
|
fn handle_get_workspace(&self, name: &str) {
|
||||||
let name = Rc::new(name.to_owned());
|
|
||||||
let ws = match self.workspaces_by_name.get(&name) {
|
|
||||||
Some(w) => w,
|
|
||||||
_ => {
|
|
||||||
let ws = self.workspace_ids.fetch_add(1);
|
|
||||||
self.workspaces_by_name.set(name.clone(), ws);
|
|
||||||
self.workspaces_by_id.set(ws, name);
|
|
||||||
ws
|
|
||||||
}
|
|
||||||
};
|
|
||||||
self.respond(Response::GetWorkspace {
|
self.respond(Response::GetWorkspace {
|
||||||
workspace: Workspace(ws),
|
workspace: self.get_workspace_by_name(&name.to_owned()),
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -818,17 +812,27 @@ impl ConfigProxyHandler {
|
||||||
fn handle_get_seat_workspace(&self, seat: Seat) -> Result<(), CphError> {
|
fn handle_get_seat_workspace(&self, seat: Seat) -> Result<(), CphError> {
|
||||||
let seat = self.get_seat(seat)?;
|
let seat = self.get_seat(seat)?;
|
||||||
let output = seat.get_output();
|
let output = seat.get_output();
|
||||||
let mut workspace = 0;
|
let mut workspace = Workspace(0);
|
||||||
if !output.is_dummy {
|
if !output.is_dummy {
|
||||||
if let Some(ws) = output.workspace.get() {
|
if let Some(ws) = output.workspace.get() {
|
||||||
if let Some(ws) = self.workspaces_by_name.get(&ws.name) {
|
workspace = self.get_workspace_by_name(&ws.name);
|
||||||
workspace = ws;
|
}
|
||||||
|
}
|
||||||
|
self.respond(Response::GetSeatWorkspace { workspace });
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
fn handle_get_seat_keyboard_workspace(&self, seat: Seat) -> Result<(), CphError> {
|
||||||
|
let seat = self.get_seat(seat)?;
|
||||||
|
let mut workspace = Workspace(0);
|
||||||
|
if let Some(output) = seat.get_keyboard_output() {
|
||||||
|
if !output.is_dummy {
|
||||||
|
if let Some(ws) = output.workspace.get() {
|
||||||
|
workspace = self.get_workspace_by_name(&ws.name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
self.respond(Response::GetSeatWorkspace {
|
self.respond(Response::GetSeatKeyboardWorkspace { workspace });
|
||||||
workspace: Workspace(workspace),
|
|
||||||
});
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1292,6 +1296,27 @@ impl ConfigProxyHandler {
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn handle_get_connector_active_workspace(&self, connector: Connector) -> Result<(), CphError> {
|
||||||
|
let output = self.get_output_node(connector)?;
|
||||||
|
let workspace = output
|
||||||
|
.workspace
|
||||||
|
.get()
|
||||||
|
.map_or(Workspace(0), |ws| self.get_workspace_by_name(&ws.name));
|
||||||
|
self.respond(Response::GetConnectorActiveWorkspace { workspace });
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
fn handle_get_connector_workspaces(&self, connector: Connector) -> Result<(), CphError> {
|
||||||
|
let output = self.get_output_node(connector)?;
|
||||||
|
let workspaces = output
|
||||||
|
.workspaces
|
||||||
|
.iter()
|
||||||
|
.map(|ws| self.get_workspace_by_name(&ws.name))
|
||||||
|
.collect::<Vec<_>>();
|
||||||
|
self.respond(Response::GetConnectorWorkspaces { workspaces });
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
fn handle_has_capability(&self, device: InputDevice, cap: Capability) -> Result<(), CphError> {
|
fn handle_has_capability(&self, device: InputDevice, cap: Capability) -> Result<(), CphError> {
|
||||||
let dev = self.get_device_handler_data(device)?;
|
let dev = self.get_device_handler_data(device)?;
|
||||||
let mut is_unknown = false;
|
let mut is_unknown = false;
|
||||||
|
|
@ -1904,6 +1929,9 @@ impl ConfigProxyHandler {
|
||||||
ClientMessage::GetSeatWorkspace { seat } => self
|
ClientMessage::GetSeatWorkspace { seat } => self
|
||||||
.handle_get_seat_workspace(seat)
|
.handle_get_seat_workspace(seat)
|
||||||
.wrn("get_seat_workspace")?,
|
.wrn("get_seat_workspace")?,
|
||||||
|
ClientMessage::GetSeatKeyboardWorkspace { seat } => self
|
||||||
|
.handle_get_seat_keyboard_workspace(seat)
|
||||||
|
.wrn("get_seat_keyboard_workspace")?,
|
||||||
ClientMessage::SetDefaultWorkspaceCapture { capture } => {
|
ClientMessage::SetDefaultWorkspaceCapture { capture } => {
|
||||||
self.handle_set_default_workspace_capture(capture)
|
self.handle_set_default_workspace_capture(capture)
|
||||||
}
|
}
|
||||||
|
|
@ -2092,6 +2120,12 @@ impl ConfigProxyHandler {
|
||||||
ClientMessage::SetShowFloatPinIcon { show } => {
|
ClientMessage::SetShowFloatPinIcon { show } => {
|
||||||
self.handle_set_show_float_pin_icon(show)
|
self.handle_set_show_float_pin_icon(show)
|
||||||
}
|
}
|
||||||
|
ClientMessage::GetConnectorActiveWorkspace { connector } => self
|
||||||
|
.handle_get_connector_active_workspace(connector)
|
||||||
|
.wrn("get_connector_active_workspace")?,
|
||||||
|
ClientMessage::GetConnectorWorkspaces { connector } => self
|
||||||
|
.handle_get_connector_workspaces(connector)
|
||||||
|
.wrn("get_connector_workspaces")?,
|
||||||
}
|
}
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -401,6 +401,10 @@ impl WlSeatGlobal {
|
||||||
self.cursor_user_group.latest_output()
|
self.cursor_user_group.latest_output()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn get_keyboard_output(&self) -> Option<Rc<OutputNode>> {
|
||||||
|
self.keyboard_node.get().node_output()
|
||||||
|
}
|
||||||
|
|
||||||
pub fn set_workspace(&self, ws: &Rc<WorkspaceNode>) {
|
pub fn set_workspace(&self, ws: &Rc<WorkspaceNode>) {
|
||||||
let tl = match self.keyboard_node.get().node_toplevel() {
|
let tl = match self.keyboard_node.get().node_toplevel() {
|
||||||
Some(tl) => tl,
|
Some(tl) => tl,
|
||||||
|
|
|
||||||
|
|
@ -122,7 +122,6 @@ pub trait Node: 'static {
|
||||||
fn node_visit_children(&self, visitor: &mut dyn NodeVisitor);
|
fn node_visit_children(&self, visitor: &mut dyn NodeVisitor);
|
||||||
fn node_visible(&self) -> bool;
|
fn node_visible(&self) -> bool;
|
||||||
fn node_absolute_position(&self) -> Rect;
|
fn node_absolute_position(&self) -> Rect;
|
||||||
#[expect(dead_code)]
|
|
||||||
fn node_output(&self) -> Option<Rc<OutputNode>>;
|
fn node_output(&self) -> Option<Rc<OutputNode>>;
|
||||||
|
|
||||||
fn node_child_title_changed(self: Rc<Self>, child: &dyn Node, title: &str) {
|
fn node_child_title_changed(self: Rc<Self>, child: &dyn Node, title: &str) {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue