Split wayland buffer code into a file

This commit is contained in:
Ian Douglas Scott 2023-02-09 14:10:31 -08:00
parent c46ab4f1e6
commit 8c690e9648
2 changed files with 63 additions and 49 deletions

58
src/wayland/buffer.rs Normal file
View file

@ -0,0 +1,58 @@
use cctk::{
screencopy::BufferInfo,
sctk::{globals::ProvidesBoundGlobal, shm::raw::RawPool},
wayland_client::{
protocol::{wl_buffer, wl_shm},
QueueHandle,
},
};
use cosmic::iced::widget::image;
pub struct Buffer {
pub pool: RawPool,
pub buffer: wl_buffer::WlBuffer,
pub buffer_info: BufferInfo,
}
impl Buffer {
pub fn new(
buffer_info: BufferInfo,
shm: &impl ProvidesBoundGlobal<wl_shm::WlShm, 1>,
qh: &QueueHandle<super::AppData>,
) -> Self {
// Assume format is already known to be valid
let mut pool =
RawPool::new((buffer_info.stride * buffer_info.height) as usize, shm).unwrap();
let format = wl_shm::Format::try_from(buffer_info.format).unwrap();
let buffer = pool.create_buffer(
0,
buffer_info.width as i32,
buffer_info.height as i32,
buffer_info.stride as i32,
format,
(),
qh,
);
Self {
pool,
buffer,
buffer_info,
}
}
// Buffer must be released by server for safety
pub unsafe fn to_image(&mut self) -> image::Handle {
// XXX is this at all a performance issue?
image::Handle::from_pixels(
self.buffer_info.width,
self.buffer_info.height,
self.pool.mmap().to_vec(),
)
}
}
impl Drop for Buffer {
fn drop(&mut self) {
self.buffer.destroy();
}
}

View file

@ -20,11 +20,10 @@ use cctk::{
sctk::{
self,
event_loop::WaylandSource,
globals::ProvidesBoundGlobal,
output::{OutputHandler, OutputState},
registry::{ProvidesRegistryState, RegistryState},
seat::{SeatHandler, SeatState},
shm::{raw::RawPool, ShmHandler, ShmState},
shm::{ShmHandler, ShmState},
},
toplevel_info::{ToplevelInfo, ToplevelInfoHandler, ToplevelInfoState},
toplevel_management::{ToplevelManagerHandler, ToplevelManagerState},
@ -52,6 +51,9 @@ use std::{
thread,
};
mod buffer;
use buffer::Buffer;
// TODO define subscription for a particular output/workspace/toplevel (but we want to rate limit?)
#[derive(Clone, Debug)]
@ -115,45 +117,6 @@ pub enum Cmd {
CaptureFilter(CaptureFilter),
}
struct Buffer {
pool: RawPool,
buffer: wl_buffer::WlBuffer,
buffer_info: BufferInfo,
}
impl Buffer {
fn new(
buffer_info: BufferInfo,
shm: &impl ProvidesBoundGlobal<wl_shm::WlShm, 1>,
qh: &QueueHandle<AppData>,
) -> Self {
// Assume format is already known to be valid
let mut pool =
RawPool::new((buffer_info.stride * buffer_info.height) as usize, shm).unwrap();
let format = wl_shm::Format::try_from(buffer_info.format).unwrap();
let buffer = pool.create_buffer(
0,
buffer_info.width as i32,
buffer_info.height as i32,
buffer_info.stride as i32,
format,
(),
qh,
);
Self {
pool,
buffer,
buffer_info,
}
}
}
impl Drop for Buffer {
fn drop(&mut self) {
self.buffer.destroy();
}
}
struct Capture {
buffer: Mutex<Option<Buffer>>,
source: CaptureSource,
@ -432,7 +395,6 @@ impl ScreencopyHandler for AppData {
&& x.format == wl_shm::Format::Abgr8888.into()
})
.unwrap();
let buf_len = buffer_info.stride * buffer_info.height;
// XXX fix in compositor
if buffer_info.width == 0 || buffer_info.height == 0 || buffer_info.stride == 0 {
@ -472,13 +434,7 @@ impl ScreencopyHandler for AppData {
}
let mut buffer = capture.buffer.lock().unwrap();
let mut buffer = buffer.as_mut().unwrap();
// XXX is this at all a performance issue?
let image = image::Handle::from_pixels(
buffer.buffer_info.width,
buffer.buffer_info.height,
buffer.pool.mmap().to_vec(),
);
let image = unsafe { buffer.as_mut().unwrap().to_image() };
let event = match &capture.source {
CaptureSource::Toplevel(toplevel) => Event::ToplevelCapture(toplevel.clone(), image),
CaptureSource::Workspace(workspace, _) => {