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:
parent
1481935472
commit
422d333d4b
1 changed files with 5 additions and 8 deletions
|
@ -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.
|
||||||
|
|
Loading…
Reference in a new issue