1
0
Fork 0
forked from wry/wry

Merge pull request #73 from mahkoh/jorth/unmapped-subsurface

render: don't warn when rendering an unmapped sub-surface
This commit is contained in:
mahkoh 2024-02-04 20:20:19 +01:00 committed by GitHub
commit bc5de5188f
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
8 changed files with 22 additions and 12 deletions

View file

@ -63,7 +63,7 @@ async fn run(screenshot: Rc<Screenshot>) {
.as_deref()
.unwrap_or("%Y-%m-%d-%H%M%S_jay.qoi");
let filename = Local::now().format(filename).to_string();
if let Err(e) = std::fs::write(&filename, &data) {
if let Err(e) = std::fs::write(&filename, data) {
fatal!("Could not write `{}`: {}", filename, ErrorFmt(e));
}
}

View file

@ -858,7 +858,7 @@ impl MethodHandlerApi for PropertyGetAllHandlerProxy {
pub mod prelude {
pub use {
super::{
types::{Bool, DictEntry, ObjectPath, Signature, Variant},
types::{Bool, DictEntry, ObjectPath, Variant},
DbusError, DbusType, Formatter, Message, MethodCall, Parser, Property, Signal,
},
std::{borrow::Cow, rc::Rc},

View file

@ -319,7 +319,7 @@ impl Forker {
level: log::Level::Error as _,
msg: format!("The ol' forker panicked: {}", pi),
};
let msg = bincode::encode_to_vec(&msg, bincode_ops()).unwrap();
let msg = bincode::encode_to_vec(msg, bincode_ops()).unwrap();
let _ = Fd::new(socket).write_all(&msg);
})
});

View file

@ -76,7 +76,15 @@ impl Cursor for CursorSurface {
let (hot_x, hot_y) = (Fixed::from_int(hot_x), Fixed::from_int(hot_y));
let x = ((x - hot_x).to_f64() * scale).round() as _;
let y = ((y - hot_y).to_f64() * scale).round() as _;
renderer.render_surface_scaled(&self.surface, x, y, None, i32::MAX, i32::MAX);
renderer.render_surface_scaled(
&self.surface,
x,
y,
None,
i32::MAX,
i32::MAX,
false,
);
} else {
renderer.render_surface(
&self.surface,

View file

@ -307,7 +307,7 @@ impl Renderer<'_> {
max_height: i32,
) {
let (x, y) = self.base.scale_point(x, y);
self.render_surface_scaled(surface, x, y, None, max_width, max_height);
self.render_surface_scaled(surface, x, y, None, max_width, max_height, false);
}
pub fn render_surface_scaled(
@ -318,12 +318,13 @@ impl Renderer<'_> {
pos_rel: Option<(i32, i32)>,
max_width: i32,
max_height: i32,
is_subsurface: bool,
) {
let children = surface.children.borrow();
let buffer = match surface.buffer.get() {
Some(b) => b,
_ => {
if !surface.is_cursor() {
if !surface.is_cursor() && !is_subsurface {
log::warn!("surface has no buffer attached");
}
return;
@ -354,6 +355,7 @@ impl Renderer<'_> {
Some((pos.x1(), pos.y1())),
max_width,
max_height,
true,
);
}
};

View file

@ -131,7 +131,7 @@ fn reopen(fd: c::c_int, need_primary: bool) -> Result<Rc<OwnedFd>, DrmError> {
}
device_node_name(fd)?
};
match uapi::open(&path, c::O_RDWR | c::O_CLOEXEC, 0) {
match uapi::open(path, c::O_RDWR | c::O_CLOEXEC, 0) {
Ok(f) => Ok(Rc::new(f)),
Err(e) => Err(DrmError::ReopenNode(e.into())),
}

View file

@ -77,7 +77,7 @@ pub fn get_node_type_from_fd(fd: c::c_int) -> Result<NodeType, OsError> {
pub fn node_is_drm(maj: u64, min: u64) -> bool {
let path = device_dir(maj, min);
uapi::stat(&path).is_ok()
uapi::stat(path).is_ok()
}
pub fn get_minor_type(min: u64) -> Result<NodeType, OsError> {
@ -102,7 +102,7 @@ pub fn get_minor_name_from_fd(fd: c::c_int, ty: NodeType) -> Result<Ustring, OsE
let (_, maj, min) = drm_stat(fd)?;
let dir = device_dir(maj, min);
let mut dir = uapi::opendir(&dir)?;
let mut dir = uapi::opendir(dir)?;
while let Some(entry) = uapi::readdir(&mut dir) {
let entry = entry?;
@ -138,7 +138,7 @@ pub fn get_device_name_from_fd2(fd: c::c_int) -> Result<Ustring, OsError> {
let (_, maj, min) = drm_stat(fd)?;
let path = uapi::format_ustr!("/sys/dev/char/{maj}:{min}/uevent");
let mut buf = vec![];
let mut br = BufReader::new(uapi::open(&path, c::O_RDONLY, 0)?);
let mut br = BufReader::new(uapi::open(path, c::O_RDONLY, 0)?);
loop {
buf.clear();
if br.read_until(b'\n', &mut buf)? == 0 {
@ -155,7 +155,7 @@ pub fn get_nodes(fd: c::c_int) -> Result<AHashMap<NodeType, CString>, OsError> {
let (_, maj, min) = drm_stat(fd)?;
let dir = device_dir(maj, min);
let mut dir = uapi::opendir(&dir)?;
let mut dir = uapi::opendir(dir)?;
let mut res = AHashMap::new();

View file

@ -29,7 +29,7 @@ impl XAuthority {
return Err(XconError::HomeNotSet);
};
let mut buf = vec![];
if let Err(e) = File::open(&path).and_then(|mut f| f.read_to_end(&mut buf)) {
if let Err(e) = File::open(path).and_then(|mut f| f.read_to_end(&mut buf)) {
return Err(XconError::ReadXAuthority(e));
}
Parser::parse(&buf)