diff --git a/yazi-core/src/manager/commands/remove.rs b/yazi-core/src/manager/commands/remove.rs index 8a391710e..a59c6ca63 100644 --- a/yazi-core/src/manager/commands/remove.rs +++ b/yazi-core/src/manager/commands/remove.rs @@ -28,17 +28,16 @@ impl Manager { if !self.active_mut().try_escape_visual() { return; } - let Some(hovered) = self.hovered().map(|h| &h.url) else { - return; - }; opt.targets = if opt.hovered { - vec![hovered.clone()] + self.hovered().map_or(vec![], |h| vec![h.url.clone()]) } else { self.selected_or_hovered(true).cloned().collect() }; - if opt.force { + if opt.targets.is_empty() { + return; + } else if opt.force { return self.remove_do(opt, tasks); } diff --git a/yazi-core/src/manager/commands/rename.rs b/yazi-core/src/manager/commands/rename.rs index c43c9153e..c8da01573 100644 --- a/yazi-core/src/manager/commands/rename.rs +++ b/yazi-core/src/manager/commands/rename.rs @@ -33,15 +33,14 @@ impl Manager { pub fn rename(&mut self, opt: Opt) { if !self.active_mut().try_escape_visual() { return; + } else if !opt.hovered && !self.active().selected.is_empty() { + return self.bulk_rename(); } + let Some(hovered) = self.hovered().map(|h| h.url_owned()) else { return; }; - if !opt.hovered && !self.active().selected.is_empty() { - return self.bulk_rename(); - } - let name = Self::empty_url_part(&hovered, &opt.empty); let cursor = match opt.cursor.as_ref() { "start" => Some(0),