forked from mirrors/jj
repo: when setting rewritten or divergent, remove from abandoned
I don't think we have any transactions that mark commit as abandoned and then later mark it as rewritten or divergent. But if we ever do, I think it should be considered just rewritten/divergent. So let's enforce that invariant by removing the old value from the set of abandoned commits.
This commit is contained in:
parent
08b5b66ad4
commit
db4b905bc9
1 changed files with 2 additions and 0 deletions
|
@ -827,6 +827,7 @@ impl MutableRepo {
|
||||||
pub fn set_rewritten_commit(&mut self, old_id: CommitId, new_id: CommitId) {
|
pub fn set_rewritten_commit(&mut self, old_id: CommitId, new_id: CommitId) {
|
||||||
assert_ne!(old_id, *self.store().root_commit_id());
|
assert_ne!(old_id, *self.store().root_commit_id());
|
||||||
self.divergent.remove(&old_id);
|
self.divergent.remove(&old_id);
|
||||||
|
self.abandoned.remove(&old_id);
|
||||||
self.parent_mapping.insert(old_id, vec![new_id]);
|
self.parent_mapping.insert(old_id, vec![new_id]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -843,6 +844,7 @@ impl MutableRepo {
|
||||||
new_ids: impl IntoIterator<Item = CommitId>,
|
new_ids: impl IntoIterator<Item = CommitId>,
|
||||||
) {
|
) {
|
||||||
assert_ne!(old_id, *self.store().root_commit_id());
|
assert_ne!(old_id, *self.store().root_commit_id());
|
||||||
|
self.abandoned.remove(&old_id);
|
||||||
self.parent_mapping
|
self.parent_mapping
|
||||||
.insert(old_id.clone(), new_ids.into_iter().collect());
|
.insert(old_id.clone(), new_ids.into_iter().collect());
|
||||||
self.divergent.insert(old_id);
|
self.divergent.insert(old_id);
|
||||||
|
|
Loading…
Reference in a new issue