forked from mirrors/jj
rewrite: minor simplification of rebase_with_empty_behavior()
This is a small refactoring to return a bit less information from the block where we merge trees.
This commit is contained in:
parent
a075a5c6ca
commit
26085f236e
1 changed files with 5 additions and 8 deletions
|
@ -214,11 +214,11 @@ impl<'repo> CommitRewriter<'repo> {
|
||||||
.map(|parent| parent.tree_id().clone())
|
.map(|parent| parent.tree_id().clone())
|
||||||
.collect_vec();
|
.collect_vec();
|
||||||
|
|
||||||
let (old_base_tree_id, new_tree_id) = if new_parent_trees == old_parent_trees {
|
let (was_empty, new_tree_id) = if new_parent_trees == old_parent_trees {
|
||||||
(
|
(
|
||||||
// Optimization: old_base_tree_id is only used for newly empty, but when the
|
// Optimization: was_empty is only used for newly empty, but when the
|
||||||
// parents haven't changed it can't be newly empty.
|
// parents haven't changed it can't be newly empty.
|
||||||
None,
|
true,
|
||||||
// Optimization: Skip merging.
|
// Optimization: Skip merging.
|
||||||
self.old_commit.tree_id().clone(),
|
self.old_commit.tree_id().clone(),
|
||||||
)
|
)
|
||||||
|
@ -227,7 +227,7 @@ impl<'repo> CommitRewriter<'repo> {
|
||||||
let new_base_tree = merge_commit_trees(self.mut_repo, &new_parents)?;
|
let new_base_tree = merge_commit_trees(self.mut_repo, &new_parents)?;
|
||||||
let old_tree = self.old_commit.tree()?;
|
let old_tree = self.old_commit.tree()?;
|
||||||
(
|
(
|
||||||
Some(old_base_tree.id()),
|
old_base_tree.id() == *self.old_commit.tree_id(),
|
||||||
new_base_tree.merge(&old_base_tree, &old_tree)?.id(),
|
new_base_tree.merge(&old_base_tree, &old_tree)?.id(),
|
||||||
)
|
)
|
||||||
};
|
};
|
||||||
|
@ -236,10 +236,7 @@ impl<'repo> CommitRewriter<'repo> {
|
||||||
if let [parent] = &new_parents[..] {
|
if let [parent] = &new_parents[..] {
|
||||||
let should_abandon = match empty {
|
let should_abandon = match empty {
|
||||||
EmptyBehaviour::Keep => false,
|
EmptyBehaviour::Keep => false,
|
||||||
EmptyBehaviour::AbandonNewlyEmpty => {
|
EmptyBehaviour::AbandonNewlyEmpty => *parent.tree_id() == new_tree_id && !was_empty,
|
||||||
*parent.tree_id() == new_tree_id
|
|
||||||
&& old_base_tree_id.map_or(false, |id| id != *self.old_commit.tree_id())
|
|
||||||
}
|
|
||||||
EmptyBehaviour::AbandonAllEmpty => *parent.tree_id() == new_tree_id,
|
EmptyBehaviour::AbandonAllEmpty => *parent.tree_id() == new_tree_id,
|
||||||
};
|
};
|
||||||
if should_abandon {
|
if should_abandon {
|
||||||
|
|
Loading…
Reference in a new issue