ok/jj
1
0
Fork 0
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:
Yuya Nishihara 2024-01-14 19:35:28 +09:00
parent b5343fb968
commit da218d19db

View file

@ -1017,14 +1017,21 @@ 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();
if view.head_ids.is_empty() {
view.head_ids.insert(root_commit_id.clone());
} else if view.head_ids.len() > 1 {
// An empty head_ids set is padded with the root_commit_id, but the
// root id is unwanted during the heads resolution.
view.head_ids.remove(root_commit_id);
view.head_ids = self view.head_ids = self
.index() .index()
.heads(&mut view.head_ids.iter()) .heads(&mut view.head_ids.iter())
.iter() .into_iter()
.cloned()
.collect(); .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
/// the visible heads. /// the visible heads.