Files
chloroway/src/wayland/wl_shm.rs
2025-05-13 13:53:02 -07:00

96 lines
3.3 KiB
Rust

use std::{error::Error, io::Write, os::unix::net::SocketAncillary, sync::atomic::Ordering, u8};
use crate::wayland::{shm, surface::UnsetErr, vec_utils::WlMessage, wl_client::WlClient};
const STRIDE: usize = 4;
impl WlClient {
pub fn wl_shm_format(event: &Vec<u8>) {
// let mut offset = 0;
// println!("Received pixel format: {:x}", event.read_u32(&mut offset));
}
pub fn wl_shm_create_pool(&self, width: usize, height: usize) -> Result<(), Box<dyn Error>> {
let mut shm_pool = self.shm_pool.lock().unwrap();
let current_id = self.current_id.fetch_add(1, Ordering::Relaxed) + 1;
self.shmpool_id.store(current_id, Ordering::Relaxed);
shm_pool.write(&vec![0xffff0000; width * height], 0);
shm_pool.rectangle(50, 50, 50, 50, 0xff00ff00);
shm_pool.circle(300, 300, 200, 0xff0000ff);
shm_pool.rounded_rectangle(450, 400, 60, 40, 16, 0xffffff00);
let object = self.shm_id.load(Ordering::Relaxed);
if object == 0 {
return Err(UnsetErr("shm_id".to_string()).into());
}
const OPCODE: u16 = 0;
const REQ_SIZE: u16 = 16;
let id = self.shmpool_id.load(Ordering::Relaxed);
let fds = [shm_pool.fd];
let shm_size = shm_pool.size;
let mut request = vec![0u8; REQ_SIZE as usize];
let mut offset: usize = 0;
// Request header
request.write_u32(&object, &mut offset);
request.write_u16(&OPCODE, &mut offset);
request.write_u16(&REQ_SIZE, &mut offset);
// Id, size of shm pool
request.write_u32(&id, &mut offset);
request.write_u32(&(shm_size as u32), &mut offset);
let mut ancillary_buf = [0u8; 32];
let mut ancillary = SocketAncillary::new(&mut ancillary_buf[..]);
if !ancillary.add_fds(&fds[..]) {
return Err(std::io::Error::new(
std::io::ErrorKind::Other,
"Failed to add FDs to ancillary data",
).into());
}
self.socket.lock().unwrap().send_vectored_with_ancillary(&[std::io::IoSlice::new(&request)], &mut ancillary)?;
Ok(())
}
pub fn wl_shm_pool_create_buffer(
&self,
shm_offset: u32,
width: u32,
height: u32
) -> Result<(), Box<dyn Error>> {
let object: u32 = self.shmpool_id.load(Ordering::Relaxed);
const REQ_SIZE: u16 = 32;
const OPCODE: u16 = 0;
let stride: u32 = width * 4;
let current_id = self.current_id.fetch_add(1, Ordering::Relaxed) + 1;
let id = current_id;
let format = 0;
let mut offset: usize = 0;
let mut request = vec![0u8; REQ_SIZE as usize];
request.write_u32(&object, &mut offset);
request.write_u16(&OPCODE, &mut offset);
request.write_u16(&REQ_SIZE, &mut offset);
request.write_u32(&id, &mut offset);
request.write_u32(&shm_offset, &mut offset);
request.write_u32(&width, &mut offset);
request.write_u32(&height, &mut offset);
request.write_u32(&stride, &mut offset);
request.write_u32(&format, &mut offset);
self.socket.lock().unwrap().write(&request)?;
self.buffer_id.store(current_id, Ordering::Relaxed);
Ok(())
}
}