cli: use new helper for updating branches after committing working copy

This makes conflicted branches pointing to the working copy get
updated when the working copy changes, just like they are when it
changes for other reason (such as `jj describe`).
This commit is contained in:
Martin von Zweigbergk 2021-09-17 23:49:29 -07:00
parent ef4cb663ae
commit 84081a5727

View file

@ -383,35 +383,7 @@ impl RepoCommandHelper {
mut_repo.set_checkout(commit.id().clone()); mut_repo.set_checkout(commit.id().clone());
// Update branches pointing to the old checkout // Update branches pointing to the old checkout
let mut branches_to_update = HashSet::new(); update_branches_after_rewrite(mut_repo);
for (branch_name, branch_target) in mut_repo.view().branches() {
match &branch_target.local_target {
None => {
// nothing to do (a deleted branch doesn't need
// updating)
}
Some(RefTarget::Normal(current_target)) => {
if current_target == old_checkout {
branches_to_update.insert(branch_name.clone());
}
}
Some(RefTarget::Conflict { adds, .. }) => {
for current_target in adds {
if current_target == old_checkout {
writeln!(
ui,
"Branch {}'s target was rewritten, but not updating it \
since it's conflicted",
branch_name
)?;
}
}
}
}
}
for branch_name in branches_to_update {
mut_repo.set_local_branch(branch_name, RefTarget::Normal(commit.id().clone()));
}
// Evolve descendants (though it currently evolves all commits) // Evolve descendants (though it currently evolves all commits)
let evolve_result = evolve_orphans(&self.settings, mut_repo)?; let evolve_result = evolve_orphans(&self.settings, mut_repo)?;