forked from mirrors/jj
repo: optimize enforce_view_invariants() to not traverse ancestors until root
Because the default index cuts off the traversal at min(generations), including the root id means all ancestors will be visited. This could be worked around at the index side, but I think it's the repo/view's responsibility. That being said, it's not uncommon to pad a revset with "root()", so it might make sense for the index to special case the root id. I also removed the redundant .clone().
This commit is contained in:
parent
b5343fb968
commit
da218d19db
1 changed files with 14 additions and 7 deletions
|
@ -1017,13 +1017,20 @@ impl MutableRepo {
|
||||||
|
|
||||||
fn enforce_view_invariants(&self, view: &mut View) {
|
fn enforce_view_invariants(&self, view: &mut View) {
|
||||||
let view = view.store_view_mut();
|
let view = view.store_view_mut();
|
||||||
view.head_ids.insert(self.store().root_commit_id().clone());
|
let root_commit_id = self.store().root_commit_id();
|
||||||
view.head_ids = self
|
if view.head_ids.is_empty() {
|
||||||
.index()
|
view.head_ids.insert(root_commit_id.clone());
|
||||||
.heads(&mut view.head_ids.iter())
|
} else if view.head_ids.len() > 1 {
|
||||||
.iter()
|
// An empty head_ids set is padded with the root_commit_id, but the
|
||||||
.cloned()
|
// root id is unwanted during the heads resolution.
|
||||||
.collect();
|
view.head_ids.remove(root_commit_id);
|
||||||
|
view.head_ids = self
|
||||||
|
.index()
|
||||||
|
.heads(&mut view.head_ids.iter())
|
||||||
|
.into_iter()
|
||||||
|
.collect();
|
||||||
|
}
|
||||||
|
assert!(!view.head_ids.is_empty());
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Ensures that the given `head` and ancestor commits are reachable from
|
/// Ensures that the given `head` and ancestor commits are reachable from
|
||||||
|
|
Loading…
Reference in a new issue