1
0
Fork 0
forked from wry/wry
wry/src/ifs/ext_idle_notification_v1.rs
2024-02-15 22:47:34 +01:00

72 lines
1.7 KiB
Rust

use {
crate::{
async_engine::SpawnedFuture,
client::{Client, ClientError},
ifs::wl_seat::WlSeatGlobal,
leaks::Tracker,
object::Object,
utils::{
asyncevent::AsyncEvent,
buffd::{MsgParser, MsgParserError},
},
wire::{ext_idle_notification_v1::*, ExtIdleNotificationV1Id},
},
std::{cell::Cell, rc::Rc},
thiserror::Error,
};
pub struct ExtIdleNotificationV1 {
pub id: ExtIdleNotificationV1Id,
pub client: Rc<Client>,
pub tracker: Tracker<Self>,
pub resume: AsyncEvent,
pub task: Cell<Option<SpawnedFuture<()>>>,
pub seat: Rc<WlSeatGlobal>,
pub duration_usec: u64,
}
impl ExtIdleNotificationV1 {
fn detach(&self) {
self.seat.remove_idle_notification(self);
self.task.take();
}
fn destroy(&self, msg: MsgParser<'_, '_>) -> Result<(), ExtIdleNotificationV1Error> {
let _req: Destroy = self.client.parse(self, msg)?;
self.detach();
self.client.remove_obj(self)?;
Ok(())
}
pub fn send_idled(&self) {
self.client.event(Idled { self_id: self.id });
}
pub fn send_resumed(&self) {
self.client.event(Resumed { self_id: self.id });
}
}
object_base! {
self = ExtIdleNotificationV1;
DESTROY => destroy,
}
impl Object for ExtIdleNotificationV1 {
fn break_loops(&self) {
self.detach();
}
}
simple_add_obj!(ExtIdleNotificationV1);
#[derive(Debug, Error)]
pub enum ExtIdleNotificationV1Error {
#[error("Parsing failed")]
MsgParserError(#[source] Box<MsgParserError>),
#[error(transparent)]
ClientError(Box<ClientError>),
}
efrom!(ExtIdleNotificationV1Error, MsgParserError);
efrom!(ExtIdleNotificationV1Error, ClientError);