Use lowest common ancestor search in History::changes_since
This commit is contained in:
parent
9a9e462183
commit
9387dfafed
@ -122,32 +122,16 @@ pub const fn at_root(&self) -> bool {
|
|||||||
/// Returns the changes since the given revision composed into a transaction.
|
/// Returns the changes since the given revision composed into a transaction.
|
||||||
/// Returns None if there are no changes between the current and given revisions.
|
/// Returns None if there are no changes between the current and given revisions.
|
||||||
pub fn changes_since(&self, revision: usize) -> Option<Transaction> {
|
pub fn changes_since(&self, revision: usize) -> Option<Transaction> {
|
||||||
use std::cmp::Ordering::*;
|
let lca = self.lowest_common_ancestor(revision, self.current);
|
||||||
|
let up = self.path_up(revision, lca);
|
||||||
|
let down = self.path_up(self.current, lca);
|
||||||
|
let up_txns = up
|
||||||
|
.iter()
|
||||||
|
.rev()
|
||||||
|
.map(|&n| self.revisions[n].inversion.clone());
|
||||||
|
let down_txns = down.iter().map(|&n| self.revisions[n].transaction.clone());
|
||||||
|
|
||||||
match revision.cmp(&self.current) {
|
up_txns.chain(down_txns).reduce(|acc, tx| tx.compose(acc))
|
||||||
Equal => None,
|
|
||||||
Less => {
|
|
||||||
let mut child = self.revisions[revision].last_child?.get();
|
|
||||||
let mut transaction = self.revisions[child].transaction.clone();
|
|
||||||
while child != self.current {
|
|
||||||
child = self.revisions[child].last_child?.get();
|
|
||||||
transaction = transaction.compose(self.revisions[child].transaction.clone());
|
|
||||||
}
|
|
||||||
Some(transaction)
|
|
||||||
}
|
|
||||||
Greater => {
|
|
||||||
let mut inversion = self.revisions[revision].inversion.clone();
|
|
||||||
let mut parent = self.revisions[revision].parent;
|
|
||||||
while parent != self.current {
|
|
||||||
parent = self.revisions[parent].parent;
|
|
||||||
if parent == 0 {
|
|
||||||
return None;
|
|
||||||
}
|
|
||||||
inversion = inversion.compose(self.revisions[parent].inversion.clone());
|
|
||||||
}
|
|
||||||
Some(inversion)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Undo the last edit.
|
/// Undo the last edit.
|
||||||
|
Loading…
Reference in New Issue
Block a user