autocommit 2022-02-09 18:28:39 CET
This commit is contained in:
parent
84d89afbde
commit
83c3fb99f9
11 changed files with 120 additions and 17 deletions
|
|
@ -29,6 +29,7 @@ const HEADER_SIZE: u32 = 16;
|
||||||
pub trait Cursor {
|
pub trait Cursor {
|
||||||
fn set_position(&self, x: i32, y: i32);
|
fn set_position(&self, x: i32, y: i32);
|
||||||
fn render(&self, renderer: &mut Renderer, x: i32, y: i32);
|
fn render(&self, renderer: &mut Renderer, x: i32, y: i32);
|
||||||
|
fn get_hotspot(&self) -> (i32, i32);
|
||||||
fn extents(&self) -> Rect;
|
fn extents(&self) -> Rect;
|
||||||
fn handle_unset(&self) {}
|
fn handle_unset(&self) {}
|
||||||
fn tick(&self) {}
|
fn tick(&self) {}
|
||||||
|
|
@ -208,6 +209,10 @@ impl Cursor for StaticCursor {
|
||||||
renderer.render_texture(&self.image.tex, x, y, ARGB8888);
|
renderer.render_texture(&self.image.tex, x, y, ARGB8888);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn get_hotspot(&self) -> (i32, i32) {
|
||||||
|
(self.image.xhot, self.image.yhot)
|
||||||
|
}
|
||||||
|
|
||||||
fn extents(&self) -> Rect {
|
fn extents(&self) -> Rect {
|
||||||
self.extents.get()
|
self.extents.get()
|
||||||
}
|
}
|
||||||
|
|
@ -235,6 +240,11 @@ impl Cursor for AnimatedCursor {
|
||||||
renderer.render_texture(&img.tex, x, y, ARGB8888);
|
renderer.render_texture(&img.tex, x, y, ARGB8888);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn get_hotspot(&self) -> (i32, i32) {
|
||||||
|
let img = &self.images[self.idx.get()];
|
||||||
|
(img.xhot, img.yhot)
|
||||||
|
}
|
||||||
|
|
||||||
fn extents(&self) -> Rect {
|
fn extents(&self) -> Rect {
|
||||||
self.extents.get()
|
self.extents.get()
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -173,7 +173,6 @@ pub fn cancel_offers<T: Vtable>(src: &T::Source) {
|
||||||
let data = T::get_source_data(src);
|
let data = T::get_source_data(src);
|
||||||
while let Some((_, offer)) = data.offers.pop() {
|
while let Some((_, offer)) = data.offers.pop() {
|
||||||
let data = T::get_offer_data(&offer);
|
let data = T::get_offer_data(&offer);
|
||||||
log::error!("cancel_offers");
|
|
||||||
data.source.take();
|
data.source.take();
|
||||||
destroy_offer::<T>(&offer);
|
destroy_offer::<T>(&offer);
|
||||||
}
|
}
|
||||||
|
|
@ -268,7 +267,6 @@ fn destroy_offer<T: Vtable>(offer: &T::Offer) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
log::error!("destroy_offer");
|
|
||||||
if let Some(src) = data.source.take() {
|
if let Some(src) = data.source.take() {
|
||||||
let src_data = T::get_source_data(&src);
|
let src_data = T::get_source_data(&src);
|
||||||
src_data.offers.remove(&T::get_offer_id(offer));
|
src_data.offers.remove(&T::get_offer_id(offer));
|
||||||
|
|
|
||||||
|
|
@ -15,6 +15,7 @@ use crate::wire::{WlDataDeviceId, WlDataOfferId, WlSurfaceId};
|
||||||
use std::rc::Rc;
|
use std::rc::Rc;
|
||||||
use thiserror::Error;
|
use thiserror::Error;
|
||||||
use uapi::OwnedFd;
|
use uapi::OwnedFd;
|
||||||
|
use crate::ifs::wl_surface::{SurfaceRole, WlSurfaceError};
|
||||||
|
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
const ROLE: u32 = 0;
|
const ROLE: u32 = 0;
|
||||||
|
|
@ -86,7 +87,14 @@ impl WlDataDevice {
|
||||||
} else {
|
} else {
|
||||||
None
|
None
|
||||||
};
|
};
|
||||||
self.seat.global.start_drag(&origin, source)?;
|
let icon = if req.icon.is_some() {
|
||||||
|
let icon = self.manager.client.lookup(req.icon)?;
|
||||||
|
icon.set_role(SurfaceRole::DndIcon)?;
|
||||||
|
Some(icon)
|
||||||
|
} else {
|
||||||
|
None
|
||||||
|
};
|
||||||
|
self.seat.global.start_drag(&origin, source, icon)?;
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -225,6 +233,8 @@ pub enum StartDragError {
|
||||||
#[error("Parsing failed")]
|
#[error("Parsing failed")]
|
||||||
ParseFailed(#[source] Box<MsgParserError>),
|
ParseFailed(#[source] Box<MsgParserError>),
|
||||||
#[error(transparent)]
|
#[error(transparent)]
|
||||||
|
WlSurfaceError(Box<WlSurfaceError>),
|
||||||
|
#[error(transparent)]
|
||||||
ClientError(Box<ClientError>),
|
ClientError(Box<ClientError>),
|
||||||
#[error(transparent)]
|
#[error(transparent)]
|
||||||
WlSeatError(Box<WlSeatError>),
|
WlSeatError(Box<WlSeatError>),
|
||||||
|
|
@ -232,6 +242,7 @@ pub enum StartDragError {
|
||||||
efrom!(StartDragError, ParseFailed, MsgParserError);
|
efrom!(StartDragError, ParseFailed, MsgParserError);
|
||||||
efrom!(StartDragError, ClientError);
|
efrom!(StartDragError, ClientError);
|
||||||
efrom!(StartDragError, WlSeatError);
|
efrom!(StartDragError, WlSeatError);
|
||||||
|
efrom!(StartDragError, WlSurfaceError);
|
||||||
|
|
||||||
#[derive(Debug, Error)]
|
#[derive(Debug, Error)]
|
||||||
pub enum SetSelectionError {
|
pub enum SetSelectionError {
|
||||||
|
|
|
||||||
|
|
@ -68,12 +68,6 @@ impl WlDataSource {
|
||||||
} else {
|
} else {
|
||||||
0
|
0
|
||||||
};
|
};
|
||||||
log::info!(
|
|
||||||
"sa = {}, ra = {}, action = {}",
|
|
||||||
server_actions,
|
|
||||||
shared.receiver_actions.get(),
|
|
||||||
action
|
|
||||||
);
|
|
||||||
if shared.selected_action.replace(action) != action {
|
if shared.selected_action.replace(action) != action {
|
||||||
for (_, offer) in &self.data.offers {
|
for (_, offer) in &self.data.offers {
|
||||||
offer.send_action(action);
|
offer.send_action(action);
|
||||||
|
|
|
||||||
|
|
@ -191,8 +191,9 @@ impl WlSeatGlobal {
|
||||||
self: &Rc<Self>,
|
self: &Rc<Self>,
|
||||||
origin: &Rc<WlSurface>,
|
origin: &Rc<WlSurface>,
|
||||||
source: Option<Rc<WlDataSource>>,
|
source: Option<Rc<WlDataSource>>,
|
||||||
|
icon: Option<Rc<WlSurface>>,
|
||||||
) -> Result<(), WlSeatError> {
|
) -> Result<(), WlSeatError> {
|
||||||
self.pointer_owner.start_drag(self, origin, source)
|
self.pointer_owner.start_drag(self, origin, source, icon)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn cancel_dnd(self: &Rc<Self>) {
|
pub fn cancel_dnd(self: &Rc<Self>) {
|
||||||
|
|
@ -253,6 +254,14 @@ impl WlSeatGlobal {
|
||||||
self.cursor.set(cursor);
|
self.cursor.set(cursor);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn dnd_icon(&self) -> Option<Rc<WlSurface>> {
|
||||||
|
self.pointer_owner.dnd_icon()
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn remove_dnd_icon(&self) {
|
||||||
|
self.pointer_owner.remove_dnd_icon();
|
||||||
|
}
|
||||||
|
|
||||||
pub fn get_cursor(&self) -> Option<Rc<dyn Cursor>> {
|
pub fn get_cursor(&self) -> Option<Rc<dyn Cursor>> {
|
||||||
self.cursor.get()
|
self.cursor.get()
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -4,7 +4,7 @@ use crate::ifs::ipc;
|
||||||
use crate::ifs::ipc::wl_data_device::WlDataDevice;
|
use crate::ifs::ipc::wl_data_device::WlDataDevice;
|
||||||
use crate::ifs::ipc::wl_data_source::WlDataSource;
|
use crate::ifs::ipc::wl_data_source::WlDataSource;
|
||||||
use crate::ifs::wl_seat::{Dnd, DroppedDnd, WlSeatError, WlSeatGlobal};
|
use crate::ifs::wl_seat::{Dnd, DroppedDnd, WlSeatError, WlSeatGlobal};
|
||||||
use crate::ifs::wl_surface::WlSurface;
|
use crate::ifs::wl_surface::{WlSurface};
|
||||||
use crate::tree::{FoundNode, Node};
|
use crate::tree::{FoundNode, Node};
|
||||||
use crate::utils::clonecell::CloneCell;
|
use crate::utils::clonecell::CloneCell;
|
||||||
use crate::utils::smallmap::SmallMap;
|
use crate::utils::smallmap::SmallMap;
|
||||||
|
|
@ -43,8 +43,9 @@ impl PointerOwnerHolder {
|
||||||
seat: &Rc<WlSeatGlobal>,
|
seat: &Rc<WlSeatGlobal>,
|
||||||
origin: &Rc<WlSurface>,
|
origin: &Rc<WlSurface>,
|
||||||
source: Option<Rc<WlDataSource>>,
|
source: Option<Rc<WlDataSource>>,
|
||||||
|
icon: Option<Rc<WlSurface>>,
|
||||||
) -> Result<(), WlSeatError> {
|
) -> Result<(), WlSeatError> {
|
||||||
self.owner.get().start_drag(seat, origin, source)
|
self.owner.get().start_drag(seat, origin, source, icon)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn cancel_dnd(&self, seat: &Rc<WlSeatGlobal>) {
|
pub fn cancel_dnd(&self, seat: &Rc<WlSeatGlobal>) {
|
||||||
|
|
@ -58,6 +59,14 @@ impl PointerOwnerHolder {
|
||||||
pub fn dnd_target_removed(&self, seat: &Rc<WlSeatGlobal>) {
|
pub fn dnd_target_removed(&self, seat: &Rc<WlSeatGlobal>) {
|
||||||
self.owner.get().dnd_target_removed(seat);
|
self.owner.get().dnd_target_removed(seat);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn dnd_icon(&self) -> Option<Rc<WlSurface>> {
|
||||||
|
self.owner.get().dnd_icon()
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn remove_dnd_icon(&self) {
|
||||||
|
self.owner.get().remove_dnd_icon()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
trait PointerOwner {
|
trait PointerOwner {
|
||||||
|
|
@ -69,10 +78,13 @@ trait PointerOwner {
|
||||||
seat: &Rc<WlSeatGlobal>,
|
seat: &Rc<WlSeatGlobal>,
|
||||||
origin: &Rc<WlSurface>,
|
origin: &Rc<WlSurface>,
|
||||||
source: Option<Rc<WlDataSource>>,
|
source: Option<Rc<WlDataSource>>,
|
||||||
|
icon: Option<Rc<WlSurface>>,
|
||||||
) -> Result<(), WlSeatError>;
|
) -> Result<(), WlSeatError>;
|
||||||
fn cancel_dnd(&self, seat: &Rc<WlSeatGlobal>);
|
fn cancel_dnd(&self, seat: &Rc<WlSeatGlobal>);
|
||||||
fn revert_to_default(&self, seat: &Rc<WlSeatGlobal>);
|
fn revert_to_default(&self, seat: &Rc<WlSeatGlobal>);
|
||||||
fn dnd_target_removed(&self, seat: &Rc<WlSeatGlobal>);
|
fn dnd_target_removed(&self, seat: &Rc<WlSeatGlobal>);
|
||||||
|
fn dnd_icon(&self) -> Option<Rc<WlSurface>>;
|
||||||
|
fn remove_dnd_icon(&self);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct DefaultPointerOwner;
|
struct DefaultPointerOwner;
|
||||||
|
|
@ -86,6 +98,7 @@ struct DndPointerOwner {
|
||||||
button: u32,
|
button: u32,
|
||||||
dnd: Dnd,
|
dnd: Dnd,
|
||||||
target: CloneCell<Rc<dyn Node>>,
|
target: CloneCell<Rc<dyn Node>>,
|
||||||
|
icon: CloneCell<Option<Rc<WlSurface>>>,
|
||||||
pos_x: Cell<Fixed>,
|
pos_x: Cell<Fixed>,
|
||||||
pos_y: Cell<Fixed>,
|
pos_y: Cell<Fixed>,
|
||||||
}
|
}
|
||||||
|
|
@ -171,8 +184,12 @@ impl PointerOwner for DefaultPointerOwner {
|
||||||
&self,
|
&self,
|
||||||
_seat: &Rc<WlSeatGlobal>,
|
_seat: &Rc<WlSeatGlobal>,
|
||||||
_origin: &Rc<WlSurface>,
|
_origin: &Rc<WlSurface>,
|
||||||
_source: Option<Rc<WlDataSource>>,
|
source: Option<Rc<WlDataSource>>,
|
||||||
|
_icon: Option<Rc<WlSurface>>,
|
||||||
) -> Result<(), WlSeatError> {
|
) -> Result<(), WlSeatError> {
|
||||||
|
if let Some(src) = source {
|
||||||
|
src.send_cancelled();
|
||||||
|
}
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -187,6 +204,14 @@ impl PointerOwner for DefaultPointerOwner {
|
||||||
fn dnd_target_removed(&self, seat: &Rc<WlSeatGlobal>) {
|
fn dnd_target_removed(&self, seat: &Rc<WlSeatGlobal>) {
|
||||||
self.cancel_dnd(seat);
|
self.cancel_dnd(seat);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn dnd_icon(&self) -> Option<Rc<WlSurface>> {
|
||||||
|
None
|
||||||
|
}
|
||||||
|
|
||||||
|
fn remove_dnd_icon(&self) {
|
||||||
|
// nothing
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl PointerOwner for GrabPointerOwner {
|
impl PointerOwner for GrabPointerOwner {
|
||||||
|
|
@ -226,6 +251,7 @@ impl PointerOwner for GrabPointerOwner {
|
||||||
seat: &Rc<WlSeatGlobal>,
|
seat: &Rc<WlSeatGlobal>,
|
||||||
origin: &Rc<WlSurface>,
|
origin: &Rc<WlSurface>,
|
||||||
src: Option<Rc<WlDataSource>>,
|
src: Option<Rc<WlDataSource>>,
|
||||||
|
icon: Option<Rc<WlSurface>>,
|
||||||
) -> Result<(), WlSeatError> {
|
) -> Result<(), WlSeatError> {
|
||||||
let button = match self.buttons.iter().next() {
|
let button = match self.buttons.iter().next() {
|
||||||
Some((b, _)) => b,
|
Some((b, _)) => b,
|
||||||
|
|
@ -237,6 +263,9 @@ impl PointerOwner for GrabPointerOwner {
|
||||||
if self.node.id() != origin.node_id {
|
if self.node.id() != origin.node_id {
|
||||||
return Ok(());
|
return Ok(());
|
||||||
}
|
}
|
||||||
|
if let Some(icon) = &icon {
|
||||||
|
icon.dnd_icons.insert(seat.id(), seat.clone());
|
||||||
|
}
|
||||||
if let Some(new) = &src {
|
if let Some(new) = &src {
|
||||||
ipc::attach_seat::<WlDataDevice>(&new, seat, ipc::Role::Dnd)?;
|
ipc::attach_seat::<WlDataDevice>(&new, seat, ipc::Role::Dnd)?;
|
||||||
}
|
}
|
||||||
|
|
@ -249,6 +278,7 @@ impl PointerOwner for GrabPointerOwner {
|
||||||
src,
|
src,
|
||||||
},
|
},
|
||||||
target: CloneCell::new(seat.state.root.clone()),
|
target: CloneCell::new(seat.state.root.clone()),
|
||||||
|
icon: CloneCell::new(icon),
|
||||||
pos_x: Cell::new(Fixed::from_int(0)),
|
pos_x: Cell::new(Fixed::from_int(0)),
|
||||||
pos_y: Cell::new(Fixed::from_int(0)),
|
pos_y: Cell::new(Fixed::from_int(0)),
|
||||||
});
|
});
|
||||||
|
|
@ -284,6 +314,14 @@ impl PointerOwner for GrabPointerOwner {
|
||||||
fn dnd_target_removed(&self, seat: &Rc<WlSeatGlobal>) {
|
fn dnd_target_removed(&self, seat: &Rc<WlSeatGlobal>) {
|
||||||
self.cancel_dnd(seat)
|
self.cancel_dnd(seat)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn dnd_icon(&self) -> Option<Rc<WlSurface>> {
|
||||||
|
None
|
||||||
|
}
|
||||||
|
|
||||||
|
fn remove_dnd_icon(&self) {
|
||||||
|
// nothing
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl PointerOwner for DndPointerOwner {
|
impl PointerOwner for DndPointerOwner {
|
||||||
|
|
@ -309,6 +347,9 @@ impl PointerOwner for DndPointerOwner {
|
||||||
ipc::detach_seat::<WlDataDevice>(src);
|
ipc::detach_seat::<WlDataDevice>(src);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if let Some(icon) = self.icon.get() {
|
||||||
|
icon.dnd_icons.remove(&seat.id());
|
||||||
|
}
|
||||||
seat.pointer_owner
|
seat.pointer_owner
|
||||||
.owner
|
.owner
|
||||||
.set(seat.pointer_owner.default.clone());
|
.set(seat.pointer_owner.default.clone());
|
||||||
|
|
@ -354,8 +395,12 @@ impl PointerOwner for DndPointerOwner {
|
||||||
&self,
|
&self,
|
||||||
_seat: &Rc<WlSeatGlobal>,
|
_seat: &Rc<WlSeatGlobal>,
|
||||||
_origin: &Rc<WlSurface>,
|
_origin: &Rc<WlSurface>,
|
||||||
_source: Option<Rc<WlDataSource>>,
|
source: Option<Rc<WlDataSource>>,
|
||||||
|
_icon: Option<Rc<WlSurface>>,
|
||||||
) -> Result<(), WlSeatError> {
|
) -> Result<(), WlSeatError> {
|
||||||
|
if let Some(src) = source {
|
||||||
|
src.send_cancelled();
|
||||||
|
}
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -366,6 +411,9 @@ impl PointerOwner for DndPointerOwner {
|
||||||
if let Some(src) = &self.dnd.src {
|
if let Some(src) = &self.dnd.src {
|
||||||
ipc::detach_seat::<WlDataDevice>(src);
|
ipc::detach_seat::<WlDataDevice>(src);
|
||||||
}
|
}
|
||||||
|
if let Some(icon) = self.icon.get() {
|
||||||
|
icon.dnd_icons.remove(&seat.id());
|
||||||
|
}
|
||||||
seat.pointer_owner
|
seat.pointer_owner
|
||||||
.owner
|
.owner
|
||||||
.set(seat.pointer_owner.default.clone());
|
.set(seat.pointer_owner.default.clone());
|
||||||
|
|
@ -381,4 +429,12 @@ impl PointerOwner for DndPointerOwner {
|
||||||
self.target.set(seat.state.root.clone());
|
self.target.set(seat.state.root.clone());
|
||||||
seat.state.tree_changed();
|
seat.state.tree_changed();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn dnd_icon(&self) -> Option<Rc<WlSurface>> {
|
||||||
|
self.icon.get()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn remove_dnd_icon(&self) {
|
||||||
|
self.icon.set(None);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -44,6 +44,7 @@ pub enum SurfaceRole {
|
||||||
Subsurface,
|
Subsurface,
|
||||||
XdgSurface,
|
XdgSurface,
|
||||||
Cursor,
|
Cursor,
|
||||||
|
DndIcon,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl SurfaceRole {
|
impl SurfaceRole {
|
||||||
|
|
@ -53,6 +54,7 @@ impl SurfaceRole {
|
||||||
SurfaceRole::Subsurface => "subsurface",
|
SurfaceRole::Subsurface => "subsurface",
|
||||||
SurfaceRole::XdgSurface => "xdg_surface",
|
SurfaceRole::XdgSurface => "xdg_surface",
|
||||||
SurfaceRole::Cursor => "cursor",
|
SurfaceRole::Cursor => "cursor",
|
||||||
|
SurfaceRole::DndIcon => "dnd_icon",
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -77,6 +79,7 @@ pub struct WlSurface {
|
||||||
seat_state: NodeSeatState,
|
seat_state: NodeSeatState,
|
||||||
xdg: CloneCell<Option<Rc<XdgSurface>>>,
|
xdg: CloneCell<Option<Rc<XdgSurface>>>,
|
||||||
cursors: SmallMap<SeatId, Rc<CursorSurface>, 1>,
|
cursors: SmallMap<SeatId, Rc<CursorSurface>, 1>,
|
||||||
|
pub dnd_icons: SmallMap<SeatId, Rc<WlSeatGlobal>, 1>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Copy, Clone, Eq, PartialEq)]
|
#[derive(Debug, Copy, Clone, Eq, PartialEq)]
|
||||||
|
|
@ -172,6 +175,7 @@ impl WlSurface {
|
||||||
seat_state: Default::default(),
|
seat_state: Default::default(),
|
||||||
xdg: Default::default(),
|
xdg: Default::default(),
|
||||||
cursors: Default::default(),
|
cursors: Default::default(),
|
||||||
|
dnd_icons: Default::default(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -234,7 +238,7 @@ impl WlSurface {
|
||||||
self.xdg.set(xdg);
|
self.xdg.set(xdg);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn set_role(&self, role: SurfaceRole) -> Result<(), WlSurfaceError> {
|
pub fn set_role(&self, role: SurfaceRole) -> Result<(), WlSurfaceError> {
|
||||||
use SurfaceRole::*;
|
use SurfaceRole::*;
|
||||||
match (self.role.get(), role) {
|
match (self.role.get(), role) {
|
||||||
(None, _) => {}
|
(None, _) => {}
|
||||||
|
|
@ -308,8 +312,15 @@ impl WlSurface {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn unset_dnd_icons(&self) {
|
||||||
|
while let Some((_, seat)) = self.dnd_icons.pop() {
|
||||||
|
seat.remove_dnd_icon()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
fn destroy(&self, parser: MsgParser<'_, '_>) -> Result<(), DestroyError> {
|
fn destroy(&self, parser: MsgParser<'_, '_>) -> Result<(), DestroyError> {
|
||||||
let _req: Destroy = self.parse(parser)?;
|
let _req: Destroy = self.parse(parser)?;
|
||||||
|
self.unset_dnd_icons();
|
||||||
self.unset_cursors();
|
self.unset_cursors();
|
||||||
self.destroy_node(true);
|
self.destroy_node(true);
|
||||||
if self.ext.get().is_some() {
|
if self.ext.get().is_some() {
|
||||||
|
|
@ -536,6 +547,7 @@ impl Object for WlSurface {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn break_loops(&self) {
|
fn break_loops(&self) {
|
||||||
|
self.unset_dnd_icons();
|
||||||
self.unset_cursors();
|
self.unset_cursors();
|
||||||
self.destroy_node(true);
|
self.destroy_node(true);
|
||||||
*self.children.borrow_mut() = None;
|
*self.children.borrow_mut() = None;
|
||||||
|
|
|
||||||
|
|
@ -76,6 +76,10 @@ impl Cursor for CursorSurface {
|
||||||
renderer.render_surface(&self.surface, x, y);
|
renderer.render_surface(&self.surface, x, y);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn get_hotspot(&self) -> (i32, i32) {
|
||||||
|
self.hotspot.get()
|
||||||
|
}
|
||||||
|
|
||||||
fn extents(&self) -> Rect {
|
fn extents(&self) -> Rect {
|
||||||
self.extents.get()
|
self.extents.get()
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -323,7 +323,6 @@ impl XdgToplevel {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn map_tiled(self: &Rc<Self>) {
|
fn map_tiled(self: &Rc<Self>) {
|
||||||
log::info!("map tiled");
|
|
||||||
let state = &self.xdg.surface.client.state;
|
let state = &self.xdg.surface.client.state;
|
||||||
let seat = state.seat_queue.last();
|
let seat = state.seat_queue.last();
|
||||||
if let Some(seat) = seat {
|
if let Some(seat) = seat {
|
||||||
|
|
|
||||||
|
|
@ -41,6 +41,17 @@ impl Framebuffer {
|
||||||
if let Some(cursor) = seat.get_cursor() {
|
if let Some(cursor) = seat.get_cursor() {
|
||||||
cursor.tick();
|
cursor.tick();
|
||||||
let extents = cursor.extents();
|
let extents = cursor.extents();
|
||||||
|
if let Some(dnd_icon) = seat.dnd_icon() {
|
||||||
|
let (x_hot, y_hot) = cursor.get_hotspot();
|
||||||
|
let extents = dnd_icon.extents.get().move_(
|
||||||
|
extents.x1() + x_hot + dnd_icon.buf_x.get(),
|
||||||
|
extents.y1() + y_hot + dnd_icon.buf_y.get(),
|
||||||
|
);
|
||||||
|
if extents.intersects(&rect) {
|
||||||
|
let (x, y) = rect.translate(extents.x1(), extents.y1());
|
||||||
|
renderer.render_surface(&dnd_icon, x, y);
|
||||||
|
}
|
||||||
|
}
|
||||||
if extents.intersects(&rect) {
|
if extents.intersects(&rect) {
|
||||||
let (x, y) = rect.translate(extents.x1(), extents.y1());
|
let (x, y) = rect.translate(extents.x1(), extents.y1());
|
||||||
cursor.render(&mut renderer, x, y);
|
cursor.render(&mut renderer, x, y);
|
||||||
|
|
|
||||||
|
|
@ -66,7 +66,6 @@ impl OutBufferSwapchain {
|
||||||
pub fn commit(&mut self) {
|
pub fn commit(&mut self) {
|
||||||
if self.cur.write_pos > 0 {
|
if self.cur.write_pos > 0 {
|
||||||
let new = self.free.pop().unwrap_or_else(|| {
|
let new = self.free.pop().unwrap_or_else(|| {
|
||||||
log::warn!("new buffer");
|
|
||||||
Default::default()
|
Default::default()
|
||||||
});
|
});
|
||||||
let old = mem::replace(&mut self.cur, new);
|
let old = mem::replace(&mut self.cur, new);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue