Skip to content

Commit

Permalink
rewrite: pass root commits into find_descendants_to_rebase()
Browse files Browse the repository at this point in the history
I'm going to add another caller that wants to rebase from given roots
instead.
  • Loading branch information
martinvonz committed Apr 17, 2024
1 parent 3922cdf commit 5e38d24
Showing 1 changed file with 11 additions and 8 deletions.
19 changes: 11 additions & 8 deletions lib/src/repo.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1106,16 +1106,18 @@ impl MutableRepo {
self.set_view(view);
}

/// Find descendants of commits in `parent_mapping` and then return them in
/// Find descendants of `root`, unless they've already been rewritten
/// (according to `parent_mapping`), and then return them in
/// an order they should be rebased in. The result is in reverse order
/// so the next value can be removed from the end.
fn find_descendants_to_rebase(&self) -> BackendResult<Vec<Commit>> {
fn find_descendants_to_rebase(&self, roots: Vec<CommitId>) -> BackendResult<Vec<Commit>> {
let store = self.store();
let old_commits_expression =
RevsetExpression::commits(self.parent_mapping.keys().cloned().collect());
let to_visit_expression = old_commits_expression
.descendants()
.minus(&old_commits_expression);
let to_visit_expression =
RevsetExpression::commits(roots)
.descendants()
.minus(&RevsetExpression::commits(
self.parent_mapping.keys().cloned().collect(),
));
let to_visit_revset = to_visit_expression
.evaluate_programmatic(self)
.map_err(|err| match err {
Expand Down Expand Up @@ -1164,7 +1166,8 @@ impl MutableRepo {
return Ok(None);
}

let to_visit = self.find_descendants_to_rebase()?;
let to_visit =
self.find_descendants_to_rebase(self.parent_mapping.keys().cloned().collect())?;
let mut rebaser = DescendantRebaser::new(settings, self, to_visit);
*rebaser.mut_options() = options;
rebaser.rebase_all()?;
Expand Down

0 comments on commit 5e38d24

Please sign in to comment.