forked from mirrors/jj
rewrite: pass a single new commit into update_checkouts()
`DescendantRebaser::update_checkouts()` only cares about the first element in `new_commit_ids`, so let's just pass in a single commit ID instead.
This commit is contained in:
parent
73729e4517
commit
8667e374b8
1 changed files with 4 additions and 5 deletions
|
@ -295,7 +295,8 @@ impl<'settings, 'repo> DescendantRebaser<'settings, 'repo> {
|
||||||
old_commit_id: CommitId,
|
old_commit_id: CommitId,
|
||||||
new_commit_ids: Vec<CommitId>,
|
new_commit_ids: Vec<CommitId>,
|
||||||
) -> Result<(), BackendError> {
|
) -> Result<(), BackendError> {
|
||||||
self.update_checkouts(&old_commit_id, &new_commit_ids)?;
|
// We arbitrarily pick a new checkout among the candidates.
|
||||||
|
self.update_checkouts(&old_commit_id, &new_commit_ids[0])?;
|
||||||
|
|
||||||
if let Some(branch_names) = self.branches.get(&old_commit_id).cloned() {
|
if let Some(branch_names) = self.branches.get(&old_commit_id).cloned() {
|
||||||
let mut branch_updates = vec![];
|
let mut branch_updates = vec![];
|
||||||
|
@ -334,7 +335,7 @@ impl<'settings, 'repo> DescendantRebaser<'settings, 'repo> {
|
||||||
fn update_checkouts(
|
fn update_checkouts(
|
||||||
&mut self,
|
&mut self,
|
||||||
old_commit_id: &CommitId,
|
old_commit_id: &CommitId,
|
||||||
new_commit_ids: &[CommitId],
|
new_commit_id: &CommitId,
|
||||||
) -> Result<(), BackendError> {
|
) -> Result<(), BackendError> {
|
||||||
let mut workspaces_to_update = vec![];
|
let mut workspaces_to_update = vec![];
|
||||||
for (workspace_id, checkout_id) in self.mut_repo.view().checkouts() {
|
for (workspace_id, checkout_id) in self.mut_repo.view().checkouts() {
|
||||||
|
@ -351,9 +352,7 @@ impl<'settings, 'repo> DescendantRebaser<'settings, 'repo> {
|
||||||
// to have the same commit checked out afterwards as well, so we avoid
|
// to have the same commit checked out afterwards as well, so we avoid
|
||||||
// calling MutableRepo::check_out() multiple times, since that might
|
// calling MutableRepo::check_out() multiple times, since that might
|
||||||
// otherwise create a separate new commit for each workspace.
|
// otherwise create a separate new commit for each workspace.
|
||||||
// We arbitrarily pick a new checkout among the candidates.
|
let new_commit = self.mut_repo.store().get_commit(new_commit_id)?;
|
||||||
let new_commit_id = new_commit_ids[0].clone();
|
|
||||||
let new_commit = self.mut_repo.store().get_commit(&new_commit_id)?;
|
|
||||||
let new_checkout_commit =
|
let new_checkout_commit =
|
||||||
self.mut_repo
|
self.mut_repo
|
||||||
.check_out(workspaces_to_update[0].clone(), self.settings, &new_commit);
|
.check_out(workspaces_to_update[0].clone(), self.settings, &new_commit);
|
||||||
|
|
Loading…
Reference in a new issue