From 9c55fcc6c510d0806bb0bccd9803f67866a7afc0 Mon Sep 17 00:00:00 2001 From: Martin von Zweigbergk Date: Thu, 11 Apr 2024 06:35:03 -0700 Subject: [PATCH] rewrite: inline and rewrite `ref_target_update()` I rewrote `old_target` and `new_target` to more accurately represent the change; the old target should be a normal (singleton) ref. --- lib/src/rewrite.rs | 17 +++++++---------- 1 file changed, 7 insertions(+), 10 deletions(-) diff --git a/lib/src/rewrite.rs b/lib/src/rewrite.rs index 1d959206d6..5df7a775fb 100644 --- a/lib/src/rewrite.rs +++ b/lib/src/rewrite.rs @@ -349,14 +349,6 @@ impl<'settings, 'repo> DescendantRebaser<'settings, 'repo> { self.rebased } - fn ref_target_update(old_id: CommitId, new_ids: Vec) -> (RefTarget, RefTarget) { - let old_ids = std::iter::repeat(old_id).take(new_ids.len()); - ( - RefTarget::from_legacy_form([], old_ids), - RefTarget::from_legacy_form([], new_ids), - ) - } - fn update_references( &mut self, old_commit_id: CommitId, @@ -393,8 +385,13 @@ impl<'settings, 'repo> DescendantRebaser<'settings, 'repo> { } } } - let (old_target, new_target) = - DescendantRebaser::ref_target_update(old_commit_id, new_commit_ids); + + let old_target = RefTarget::normal(old_commit_id.clone()); + assert!(!new_commit_ids.is_empty()); + let new_target = RefTarget::from_legacy_form( + std::iter::repeat(old_commit_id).take(new_commit_ids.len() - 1), + new_commit_ids, + ); for branch_name in &branch_updates { self.mut_repo .merge_local_branch(branch_name, &old_target, &new_target);