Skip to content

Commit

Permalink
Merge pull request #73 from mahkoh/jorth/unmapped-subsurface
Browse files Browse the repository at this point in the history
render: don't warn when rendering an unmapped sub-surface
  • Loading branch information
mahkoh authored Feb 4, 2024
2 parents 3d7bf39 + 58cab88 commit bc5de51
Show file tree
Hide file tree
Showing 8 changed files with 22 additions and 12 deletions.
2 changes: 1 addition & 1 deletion src/cli/screenshot.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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));
}
}
Expand Down
2 changes: 1 addition & 1 deletion src/dbus.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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},
Expand Down
2 changes: 1 addition & 1 deletion src/forker.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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);
})
});
Expand Down
10 changes: 9 additions & 1 deletion src/ifs/wl_surface/cursor.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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,
Expand Down
6 changes: 4 additions & 2 deletions src/renderer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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(
Expand All @@ -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;
Expand Down Expand Up @@ -354,6 +355,7 @@ impl Renderer<'_> {
Some((pos.x1(), pos.y1())),
max_width,
max_height,
true,
);
}
};
Expand Down
2 changes: 1 addition & 1 deletion src/video/drm.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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())),
}
Expand Down
8 changes: 4 additions & 4 deletions src/video/drm/sys.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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> {
Expand All @@ -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?;
Expand Down Expand Up @@ -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 {
Expand All @@ -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();

Expand Down
2 changes: 1 addition & 1 deletion src/xcon/xauthority.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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)
Expand Down

0 comments on commit bc5de51

Please sign in to comment.