tree: ensure Tree outlives its iterator on dropping self-referential struct

Just for sanity. It wouldn't matter unless the iterator implements Drop.

https://doc.rust-lang.org/reference/destructors.html
This commit is contained in:
Yuya Nishihara 2022-12-08 21:06:02 +09:00
parent 1f3cfcec9d
commit ffbd6eb945

View file

@ -230,8 +230,9 @@ impl Tree {
} }
pub struct TreeEntriesIterator<'matcher> { pub struct TreeEntriesIterator<'matcher> {
tree: Pin<Box<Tree>>,
entry_iterator: TreeEntriesNonRecursiveIterator<'static>, entry_iterator: TreeEntriesNonRecursiveIterator<'static>,
// On drop, tree must outlive entry_iterator
tree: Pin<Box<Tree>>,
subdir_iterator: Option<Box<TreeEntriesIterator<'matcher>>>, subdir_iterator: Option<Box<TreeEntriesIterator<'matcher>>>,
matcher: &'matcher dyn Matcher, matcher: &'matcher dyn Matcher,
} }
@ -244,8 +245,8 @@ impl<'matcher> TreeEntriesIterator<'matcher> {
let entry_iterator: TreeEntriesNonRecursiveIterator<'static> = let entry_iterator: TreeEntriesNonRecursiveIterator<'static> =
unsafe { std::mem::transmute(entry_iterator) }; unsafe { std::mem::transmute(entry_iterator) };
Self { Self {
tree,
entry_iterator, entry_iterator,
tree,
subdir_iterator: None, subdir_iterator: None,
matcher, matcher,
} }
@ -402,11 +403,12 @@ pub fn recursive_tree_diff(root1: Tree, root2: Tree, matcher: &dyn Matcher) -> T
pub struct TreeDiffIterator<'matcher> { pub struct TreeDiffIterator<'matcher> {
dir: RepoPath, dir: RepoPath,
tree1: Pin<Box<Tree>>,
tree2: Pin<Box<Tree>>,
matcher: &'matcher dyn Matcher, matcher: &'matcher dyn Matcher,
// Iterator over the diffs between tree1 and tree2 // Iterator over the diffs between tree1 and tree2
entry_iterator: TreeEntryDiffIterator<'static, 'matcher>, entry_iterator: TreeEntryDiffIterator<'static, 'matcher>,
// On drop, tree1 and tree2 must outlive entry_iterator
tree1: Pin<Box<Tree>>,
tree2: Pin<Box<Tree>>,
// This is used for making sure that when a directory gets replaced by a file, we // This is used for making sure that when a directory gets replaced by a file, we
// yield the value for the addition of the file after we yield the values // yield the value for the addition of the file after we yield the values
// for removing files in the directory. // for removing files in the directory.
@ -429,10 +431,10 @@ impl<'matcher> TreeDiffIterator<'matcher> {
unsafe { std::mem::transmute(root_entry_iterator) }; unsafe { std::mem::transmute(root_entry_iterator) };
Self { Self {
dir, dir,
tree1,
tree2,
matcher, matcher,
entry_iterator: root_entry_iterator, entry_iterator: root_entry_iterator,
tree1,
tree2,
added_file: None, added_file: None,
subdir_iterator: None, subdir_iterator: None,
} }