forked from mirrors/jj
copy-tracking: extract next_impl from next in diff iter/stream
This commit is contained in:
parent
34b0f87584
commit
0349d9ead3
1 changed files with 61 additions and 50 deletions
|
@ -663,52 +663,8 @@ impl<'matcher> TreeDiffIterator<'matcher> {
|
||||||
Ok(Merge::resolved(Tree::empty(store.clone(), dir.to_owned())))
|
Ok(Merge::resolved(Tree::empty(store.clone(), dir.to_owned())))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
impl TreeDiffDirItem {
|
fn next_impl(&mut self) -> Option<TreeDiffEntry> {
|
||||||
fn from_trees(
|
|
||||||
dir: &RepoPath,
|
|
||||||
trees1: &Merge<Tree>,
|
|
||||||
trees2: &Merge<Tree>,
|
|
||||||
matcher: &dyn Matcher,
|
|
||||||
) -> Self {
|
|
||||||
let mut entries = vec![];
|
|
||||||
for (name, before, after) in merged_tree_entry_diff(trees1, trees2) {
|
|
||||||
let path = dir.join(name);
|
|
||||||
let before = before.to_merge();
|
|
||||||
let after = after.to_merge();
|
|
||||||
let tree_before = before.is_tree();
|
|
||||||
let tree_after = after.is_tree();
|
|
||||||
// Check if trees and files match, but only if either side is a tree or a file
|
|
||||||
// (don't query the matcher unnecessarily).
|
|
||||||
let tree_matches = (tree_before || tree_after) && !matcher.visit(&path).is_nothing();
|
|
||||||
let file_matches = (!tree_before || !tree_after) && matcher.matches(&path);
|
|
||||||
|
|
||||||
// Replace trees or files that don't match by `Merge::absent()`
|
|
||||||
let before = if (tree_before && tree_matches) || (!tree_before && file_matches) {
|
|
||||||
before
|
|
||||||
} else {
|
|
||||||
Merge::absent()
|
|
||||||
};
|
|
||||||
let after = if (tree_after && tree_matches) || (!tree_after && file_matches) {
|
|
||||||
after
|
|
||||||
} else {
|
|
||||||
Merge::absent()
|
|
||||||
};
|
|
||||||
if before.is_absent() && after.is_absent() {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
entries.push((path, before, after));
|
|
||||||
}
|
|
||||||
entries.reverse();
|
|
||||||
Self { entries }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Iterator for TreeDiffIterator<'_> {
|
|
||||||
type Item = TreeDiffEntry;
|
|
||||||
|
|
||||||
fn next(&mut self) -> Option<Self::Item> {
|
|
||||||
while let Some(top) = self.stack.last_mut() {
|
while let Some(top) = self.stack.last_mut() {
|
||||||
let (path, before, after) = match top {
|
let (path, before, after) = match top {
|
||||||
TreeDiffItem::Dir(dir) => match dir.entries.pop() {
|
TreeDiffItem::Dir(dir) => match dir.entries.pop() {
|
||||||
|
@ -788,6 +744,54 @@ impl Iterator for TreeDiffIterator<'_> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl TreeDiffDirItem {
|
||||||
|
fn from_trees(
|
||||||
|
dir: &RepoPath,
|
||||||
|
trees1: &Merge<Tree>,
|
||||||
|
trees2: &Merge<Tree>,
|
||||||
|
matcher: &dyn Matcher,
|
||||||
|
) -> Self {
|
||||||
|
let mut entries = vec![];
|
||||||
|
for (name, before, after) in merged_tree_entry_diff(trees1, trees2) {
|
||||||
|
let path = dir.join(name);
|
||||||
|
let before = before.to_merge();
|
||||||
|
let after = after.to_merge();
|
||||||
|
let tree_before = before.is_tree();
|
||||||
|
let tree_after = after.is_tree();
|
||||||
|
// Check if trees and files match, but only if either side is a tree or a file
|
||||||
|
// (don't query the matcher unnecessarily).
|
||||||
|
let tree_matches = (tree_before || tree_after) && !matcher.visit(&path).is_nothing();
|
||||||
|
let file_matches = (!tree_before || !tree_after) && matcher.matches(&path);
|
||||||
|
|
||||||
|
// Replace trees or files that don't match by `Merge::absent()`
|
||||||
|
let before = if (tree_before && tree_matches) || (!tree_before && file_matches) {
|
||||||
|
before
|
||||||
|
} else {
|
||||||
|
Merge::absent()
|
||||||
|
};
|
||||||
|
let after = if (tree_after && tree_matches) || (!tree_after && file_matches) {
|
||||||
|
after
|
||||||
|
} else {
|
||||||
|
Merge::absent()
|
||||||
|
};
|
||||||
|
if before.is_absent() && after.is_absent() {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
entries.push((path, before, after));
|
||||||
|
}
|
||||||
|
entries.reverse();
|
||||||
|
Self { entries }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Iterator for TreeDiffIterator<'_> {
|
||||||
|
type Item = TreeDiffEntry;
|
||||||
|
|
||||||
|
fn next(&mut self) -> Option<Self::Item> {
|
||||||
|
self.next_impl()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Stream of differences between two trees.
|
/// Stream of differences between two trees.
|
||||||
pub struct TreeDiffStreamImpl<'matcher> {
|
pub struct TreeDiffStreamImpl<'matcher> {
|
||||||
matcher: &'matcher dyn Matcher,
|
matcher: &'matcher dyn Matcher,
|
||||||
|
@ -997,12 +1001,11 @@ impl<'matcher> TreeDiffStreamImpl<'matcher> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
impl Stream for TreeDiffStreamImpl<'_> {
|
fn poll_next_impl(
|
||||||
type Item = TreeDiffEntry;
|
mut self: Pin<&mut Self>,
|
||||||
|
cx: &mut Context<'_>,
|
||||||
fn poll_next(mut self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Option<Self::Item>> {
|
) -> Poll<Option<TreeDiffEntry>> {
|
||||||
// Go through all pending tree futures and poll them.
|
// Go through all pending tree futures and poll them.
|
||||||
self.poll_tree_futures(cx);
|
self.poll_tree_futures(cx);
|
||||||
|
|
||||||
|
@ -1054,6 +1057,14 @@ impl Stream for TreeDiffStreamImpl<'_> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl Stream for TreeDiffStreamImpl<'_> {
|
||||||
|
type Item = TreeDiffEntry;
|
||||||
|
|
||||||
|
fn poll_next(mut self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Option<Self::Item>> {
|
||||||
|
self.as_mut().poll_next_impl(cx)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Helps with writing trees with conflicts. You start by creating an instance
|
/// Helps with writing trees with conflicts. You start by creating an instance
|
||||||
/// of this type with one or more base trees. You then add overrides on top. The
|
/// of this type with one or more base trees. You then add overrides on top. The
|
||||||
/// overrides may be conflicts. Then you can write the result as a legacy tree
|
/// overrides may be conflicts. Then you can write the result as a legacy tree
|
||||||
|
|
Loading…
Reference in a new issue