ok/jj
1
0
Fork 0
forked from mirrors/jj

index: make heads() return result in index order instead of hash order

It's nice to have a non-random order for tests (we can revisit later
if it shows up in profiling). I'm changing the order to be the index
order so the future caller of `heads_pos()` (not `heads()`) will also
get consistent order.
This commit is contained in:
Martin von Zweigbergk 2021-02-23 17:19:28 -08:00
parent 1481935472
commit 422d333d4b

View file

@ -15,7 +15,7 @@
extern crate byteorder; extern crate byteorder;
use std::cmp::{max, min, Ordering}; use std::cmp::{max, min, Ordering};
use std::collections::{BTreeMap, BinaryHeap, HashMap, HashSet}; use std::collections::{BTreeMap, BTreeSet, BinaryHeap, HashMap, HashSet};
use std::fs::File; use std::fs::File;
use std::io; use std::io;
use std::io::{Cursor, Read, Write}; use std::io::{Cursor, Read, Write};
@ -737,21 +737,18 @@ impl<'a> CompositeIndex<'a> {
&self, &self,
candidate_ids: impl IntoIterator<Item = &'candidates CommitId>, candidate_ids: impl IntoIterator<Item = &'candidates CommitId>,
) -> Vec<CommitId> { ) -> Vec<CommitId> {
let candidate_positions: HashSet<_> = candidate_ids let candidate_positions: BTreeSet<_> = candidate_ids
.into_iter() .into_iter()
.map(|id| self.commit_id_to_pos(id).unwrap()) .map(|id| self.commit_id_to_pos(id).unwrap())
.collect(); .collect();
let mut heads: Vec<_> = self self.heads_pos(candidate_positions)
.heads_pos(candidate_positions)
.iter() .iter()
.map(|pos| self.entry_by_pos(*pos).commit_id()) .map(|pos| self.entry_by_pos(*pos).commit_id())
.collect(); .collect()
heads.sort();
heads
} }
pub fn heads_pos(&self, mut candidate_positions: HashSet<u32>) -> HashSet<u32> { fn heads_pos(&self, mut candidate_positions: BTreeSet<u32>) -> BTreeSet<u32> {
// Add all parents of the candidates to the work queue. The parents and their // Add all parents of the candidates to the work queue. The parents and their
// ancestors are not heads. // ancestors are not heads.
// Also find the smallest generation number among the candidates. // Also find the smallest generation number among the candidates.