protocol/workspace: Store ext/cosmic specific capabilities
This means a change to an ext capability will not send a redundant cosmic capability event, and vice versa. This will be more important when cosmic-specific states are added. Since those may change often.
This commit is contained in:
parent
dea7f2f825
commit
f9dd922af3
2 changed files with 43 additions and 40 deletions
|
|
@ -20,7 +20,7 @@ use super::{
|
|||
|
||||
#[derive(Default)]
|
||||
pub struct CosmicWorkspaceV2DataInner {
|
||||
capabilities: Option<WorkspaceCapabilities>,
|
||||
capabilities: Option<zcosmic_workspace_handle_v2::WorkspaceCapabilities>,
|
||||
tiling: Option<zcosmic_workspace_handle_v2::TilingState>,
|
||||
}
|
||||
|
||||
|
|
@ -190,22 +190,22 @@ pub fn send_workspace_to_client(
|
|||
.lock()
|
||||
.unwrap();
|
||||
|
||||
if handle_state.capabilities != Some(workspace.capabilities) {
|
||||
let caps = workspace
|
||||
.capabilities
|
||||
.iter()
|
||||
.filter_map(|cap| match cap {
|
||||
WorkspaceCapabilities::Rename => {
|
||||
Some(zcosmic_workspace_handle_v2::WorkspaceCapabilities::Rename)
|
||||
}
|
||||
WorkspaceCapabilities::SetTilingState => {
|
||||
Some(zcosmic_workspace_handle_v2::WorkspaceCapabilities::SetTilingState)
|
||||
}
|
||||
_ => None,
|
||||
})
|
||||
.collect::<zcosmic_workspace_handle_v2::WorkspaceCapabilities>();
|
||||
instance.capabilities(caps);
|
||||
handle_state.capabilities = Some(workspace.capabilities);
|
||||
let capabilities = workspace
|
||||
.capabilities
|
||||
.iter()
|
||||
.filter_map(|cap| match cap {
|
||||
WorkspaceCapabilities::Rename => {
|
||||
Some(zcosmic_workspace_handle_v2::WorkspaceCapabilities::Rename)
|
||||
}
|
||||
WorkspaceCapabilities::SetTilingState => {
|
||||
Some(zcosmic_workspace_handle_v2::WorkspaceCapabilities::SetTilingState)
|
||||
}
|
||||
_ => None,
|
||||
})
|
||||
.collect::<zcosmic_workspace_handle_v2::WorkspaceCapabilities>();
|
||||
if handle_state.capabilities != Some(capabilities) {
|
||||
instance.capabilities(capabilities);
|
||||
handle_state.capabilities = Some(capabilities);
|
||||
changed = true;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -23,7 +23,7 @@ use smithay::reexports::wayland_protocols::ext::workspace::v1::server::{
|
|||
#[derive(Default)]
|
||||
pub struct WorkspaceDataInner {
|
||||
name: String,
|
||||
capabilities: Option<WorkspaceCapabilities>,
|
||||
capabilities: Option<ext_workspace_handle_v1::WorkspaceCapabilities>,
|
||||
coordinates: Vec<u32>,
|
||||
states: Option<ext_workspace_handle_v1::State>,
|
||||
pub(super) cosmic_v2_handle: Option<Weak<ZcosmicWorkspaceHandleV2>>,
|
||||
|
|
@ -416,6 +416,7 @@ where
|
|||
handle_state.name = workspace.name.clone();
|
||||
changed = true;
|
||||
}
|
||||
|
||||
if handle_state.coordinates != workspace.coordinates {
|
||||
let coords = workspace
|
||||
.coordinates
|
||||
|
|
@ -426,30 +427,32 @@ where
|
|||
handle_state.coordinates = workspace.coordinates.clone();
|
||||
changed = true;
|
||||
}
|
||||
if handle_state.capabilities != Some(workspace.capabilities) {
|
||||
let caps = workspace
|
||||
.capabilities
|
||||
.iter()
|
||||
.filter_map(|cap| match cap {
|
||||
WorkspaceCapabilities::Activate => {
|
||||
Some(ext_workspace_handle_v1::WorkspaceCapabilities::Activate)
|
||||
}
|
||||
WorkspaceCapabilities::Deactivate => {
|
||||
Some(ext_workspace_handle_v1::WorkspaceCapabilities::Deactivate)
|
||||
}
|
||||
WorkspaceCapabilities::Remove => {
|
||||
Some(ext_workspace_handle_v1::WorkspaceCapabilities::Remove)
|
||||
}
|
||||
WorkspaceCapabilities::Assign => {
|
||||
Some(ext_workspace_handle_v1::WorkspaceCapabilities::Assign)
|
||||
}
|
||||
_ => None,
|
||||
})
|
||||
.collect::<ext_workspace_handle_v1::WorkspaceCapabilities>();
|
||||
instance.capabilities(caps);
|
||||
handle_state.capabilities = Some(workspace.capabilities.clone());
|
||||
|
||||
let capabilities = workspace
|
||||
.capabilities
|
||||
.iter()
|
||||
.filter_map(|cap| match cap {
|
||||
WorkspaceCapabilities::Activate => {
|
||||
Some(ext_workspace_handle_v1::WorkspaceCapabilities::Activate)
|
||||
}
|
||||
WorkspaceCapabilities::Deactivate => {
|
||||
Some(ext_workspace_handle_v1::WorkspaceCapabilities::Deactivate)
|
||||
}
|
||||
WorkspaceCapabilities::Remove => {
|
||||
Some(ext_workspace_handle_v1::WorkspaceCapabilities::Remove)
|
||||
}
|
||||
WorkspaceCapabilities::Assign => {
|
||||
Some(ext_workspace_handle_v1::WorkspaceCapabilities::Assign)
|
||||
}
|
||||
_ => None,
|
||||
})
|
||||
.collect::<ext_workspace_handle_v1::WorkspaceCapabilities>();
|
||||
if handle_state.capabilities != Some(capabilities) {
|
||||
instance.capabilities(capabilities);
|
||||
handle_state.capabilities = Some(capabilities);
|
||||
changed = true;
|
||||
}
|
||||
|
||||
if handle_state.states != Some(workspace.states) {
|
||||
instance.state(workspace.states);
|
||||
handle_state.states = Some(workspace.states.clone());
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue