use clap_complete::ArgValueCandidates;
use itertools::Itertools as _;
use jj_lib::op_store::RefTarget;
use super::warn_unmatched_local_bookmarks;
use crate::cli_util::CommandHelper;
use crate::command_error::CommandError;
use crate::complete;
use crate::revset_util::parse_union_name_patterns;
use crate::ui::Ui;
#[derive(clap::Args, Clone, Debug)]
pub struct BookmarkDeleteArgs {
#[arg(required = true)]
#[arg(add = ArgValueCandidates::new(complete::local_bookmarks))]
names: Vec<String>,
}
pub async fn cmd_bookmark_delete(
ui: &mut Ui,
command: &CommandHelper,
args: &BookmarkDeleteArgs,
) -> Result<(), CommandError> {
let mut workspace_command = command.workspace_helper(ui)?;
let repo = workspace_command.repo().clone();
let name_expr = parse_union_name_patterns(ui, &args.names)?;
let name_matcher = name_expr.to_matcher();
let matched_bookmarks = repo
.view()
.local_bookmarks_matching(&name_matcher)
.collect_vec();
warn_unmatched_local_bookmarks(ui, repo.view(), &name_expr)?;
if matched_bookmarks.is_empty() {
writeln!(ui.status(), "No bookmarks to delete.")?;
return Ok(());
}
let mut tx = workspace_command.start_transaction();
for (name, _) in &matched_bookmarks {
tx.repo_mut()
.set_local_bookmark_target(name, RefTarget::absent());
}
writeln!(
ui.status(),
"Deleted {} bookmarks.",
matched_bookmarks.len()
)?;
tx.finish(
ui,
format!(
"delete bookmark {}",
matched_bookmarks
.iter()
.map(|(name, _)| name.as_symbol())
.join(", ")
),
)
.await?;
Ok(())
}