Merge pull request #1996 from zed-industries/add-close-clean-items-command

Add close clean items command
This commit is contained in:
Joseph T. Lyons 2022-12-29 14:12:04 -05:00 committed by GitHub
commit 0f818f2458
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 37 additions and 19 deletions

View file

@ -21,6 +21,7 @@
"alt-cmd-right": "pane::ActivateNextItem", "alt-cmd-right": "pane::ActivateNextItem",
"cmd-w": "pane::CloseActiveItem", "cmd-w": "pane::CloseActiveItem",
"alt-cmd-t": "pane::CloseInactiveItems", "alt-cmd-t": "pane::CloseInactiveItems",
"cmd-k u": "pane::CloseCleanItems",
"cmd-k cmd-w": "pane::CloseAllItems", "cmd-k cmd-w": "pane::CloseAllItems",
"cmd-shift-w": "workspace::CloseWindow", "cmd-shift-w": "workspace::CloseWindow",
"cmd-s": "workspace::Save", "cmd-s": "workspace::Save",

View file

@ -44,6 +44,7 @@ actions!(
ActivateLastItem, ActivateLastItem,
CloseActiveItem, CloseActiveItem,
CloseInactiveItems, CloseInactiveItems,
CloseCleanItems,
CloseAllItems, CloseAllItems,
ReopenClosedItem, ReopenClosedItem,
SplitLeft, SplitLeft,
@ -123,6 +124,7 @@ pub fn init(cx: &mut MutableAppContext) {
}); });
cx.add_async_action(Pane::close_active_item); cx.add_async_action(Pane::close_active_item);
cx.add_async_action(Pane::close_inactive_items); cx.add_async_action(Pane::close_inactive_items);
cx.add_async_action(Pane::close_clean_items);
cx.add_async_action(Pane::close_all_items); cx.add_async_action(Pane::close_all_items);
cx.add_async_action(|workspace: &mut Workspace, action: &CloseItem, cx| { cx.add_async_action(|workspace: &mut Workspace, action: &CloseItem, cx| {
let pane = action.pane.upgrade(cx)?; let pane = action.pane.upgrade(cx)?;
@ -263,6 +265,7 @@ pub enum ReorderBehavior {
enum ItemType { enum ItemType {
Active, Active,
Inactive, Inactive,
Clean,
All, All,
} }
@ -723,6 +726,14 @@ impl Pane {
Self::close_main(workspace, ItemType::All, cx) Self::close_main(workspace, ItemType::All, cx)
} }
pub fn close_clean_items(
workspace: &mut Workspace,
_: &CloseCleanItems,
cx: &mut ViewContext<Workspace>,
) -> Option<Task<Result<()>>> {
Self::close_main(workspace, ItemType::Clean, cx)
}
fn close_main( fn close_main(
workspace: &mut Workspace, workspace: &mut Workspace,
close_item_type: ItemType, close_item_type: ItemType,
@ -731,9 +742,15 @@ impl Pane {
let pane_handle = workspace.active_pane().clone(); let pane_handle = workspace.active_pane().clone();
let pane = pane_handle.read(cx); let pane = pane_handle.read(cx);
if pane.items.is_empty() { if pane.items.is_empty() {
None return None;
} else { }
let active_item_id = pane.items[pane.active_item_index].id(); let active_item_id = pane.items[pane.active_item_index].id();
let clean_item_ids: Vec<_> = pane
.items()
.filter(|item| !item.is_dirty(cx))
.map(|item| item.id())
.collect();
let task = let task =
Self::close_items( Self::close_items(
workspace, workspace,
@ -742,6 +759,7 @@ impl Pane {
move |item_id| match close_item_type { move |item_id| match close_item_type {
ItemType::Active => item_id == active_item_id, ItemType::Active => item_id == active_item_id,
ItemType::Inactive => item_id != active_item_id, ItemType::Inactive => item_id != active_item_id,
ItemType::Clean => clean_item_ids.contains(&item_id),
ItemType::All => true, ItemType::All => true,
}, },
); );
@ -751,7 +769,6 @@ impl Pane {
Ok(()) Ok(())
})) }))
} }
}
pub fn close_item( pub fn close_item(
workspace: &mut Workspace, workspace: &mut Workspace,