1
0
Fork 0
forked from wry/wry

screencapture: implement ext_foreign_toplevel_image_capture_source_manager_v1

This commit is contained in:
Julian Orth 2024-10-08 22:36:47 +02:00
parent 40bce507a6
commit e91993fb18
8 changed files with 185 additions and 51 deletions

View file

@ -78,7 +78,11 @@ impl Object for ExtForeignToplevelHandleV1 {
}
}
simple_add_obj!(ExtForeignToplevelHandleV1);
dedicated_add_obj!(
ExtForeignToplevelHandleV1,
ExtForeignToplevelHandleV1Id,
foreign_toplevel_handles
);
#[derive(Debug, Error)]
pub enum ExtForeignToplevelHandleV1Error {

View file

@ -0,0 +1,110 @@
use {
crate::{
client::{Client, ClientError},
globals::{Global, GlobalName},
ifs::ext_image_capture_source_v1::{ExtImageCaptureSourceV1, ImageCaptureSource},
leaks::Tracker,
object::{Object, Version},
wire::{
ext_foreign_toplevel_image_capture_source_manager_v1::*,
ExtForeignToplevelImageCaptureSourceManagerV1Id,
},
},
std::rc::Rc,
thiserror::Error,
};
pub struct ExtForeignToplevelImageCaptureSourceManagerV1Global {
pub name: GlobalName,
}
impl ExtForeignToplevelImageCaptureSourceManagerV1Global {
pub fn new(name: GlobalName) -> Self {
Self { name }
}
fn bind_(
self: Rc<Self>,
id: ExtForeignToplevelImageCaptureSourceManagerV1Id,
client: &Rc<Client>,
version: Version,
) -> Result<(), ExtForeignToplevelImageCaptureSourceManagerV1Error> {
let obj = Rc::new(ExtForeignToplevelImageCaptureSourceManagerV1 {
id,
client: client.clone(),
tracker: Default::default(),
version,
});
track!(client, obj);
client.add_client_obj(&obj)?;
Ok(())
}
}
pub struct ExtForeignToplevelImageCaptureSourceManagerV1 {
pub id: ExtForeignToplevelImageCaptureSourceManagerV1Id,
pub client: Rc<Client>,
pub tracker: Tracker<Self>,
pub version: Version,
}
impl ExtForeignToplevelImageCaptureSourceManagerV1RequestHandler
for ExtForeignToplevelImageCaptureSourceManagerV1
{
type Error = ExtForeignToplevelImageCaptureSourceManagerV1Error;
fn create_source(&self, req: CreateSource, _slf: &Rc<Self>) -> Result<(), Self::Error> {
let handle = self.client.lookup(req.toplevel_handle)?;
let obj = Rc::new(ExtImageCaptureSourceV1 {
id: req.source,
client: self.client.clone(),
tracker: Default::default(),
ty: ImageCaptureSource::Toplevel(handle.toplevel.clone()),
});
track!(self.client, obj);
self.client.add_client_obj(&obj)?;
Ok(())
}
fn destroy(&self, _req: Destroy, _slf: &Rc<Self>) -> Result<(), Self::Error> {
self.client.remove_obj(self)?;
Ok(())
}
}
global_base!(
ExtForeignToplevelImageCaptureSourceManagerV1Global,
ExtForeignToplevelImageCaptureSourceManagerV1,
ExtForeignToplevelImageCaptureSourceManagerV1Error
);
impl Global for ExtForeignToplevelImageCaptureSourceManagerV1Global {
fn singleton(&self) -> bool {
true
}
fn version(&self) -> u32 {
1
}
}
simple_add_global!(ExtForeignToplevelImageCaptureSourceManagerV1Global);
object_base! {
self = ExtForeignToplevelImageCaptureSourceManagerV1;
version = self.version;
}
impl Object for ExtForeignToplevelImageCaptureSourceManagerV1 {}
simple_add_obj!(ExtForeignToplevelImageCaptureSourceManagerV1);
#[derive(Debug, Error)]
pub enum ExtForeignToplevelImageCaptureSourceManagerV1Error {
#[error(transparent)]
ClientError(Box<ClientError>),
}
efrom!(
ExtForeignToplevelImageCaptureSourceManagerV1Error,
ClientError
);

View file

@ -4,6 +4,7 @@ use {
ifs::wl_output::OutputGlobalOpt,
leaks::Tracker,
object::{Object, Version},
tree::ToplevelOpt,
wire::{ext_image_capture_source_v1::*, ExtImageCaptureSourceV1Id},
},
std::rc::Rc,
@ -14,6 +15,7 @@ use {
#[derive(Clone)]
pub enum ImageCaptureSource {
Output(Rc<OutputGlobalOpt>),
Toplevel(ToplevelOpt),
}
pub struct ExtImageCaptureSourceV1 {