From ffbd6eb9459dde28ba0879b6b9d22eb0ad447844 Mon Sep 17 00:00:00 2001 From: Yuya Nishihara Date: Thu, 8 Dec 2022 21:06:02 +0900 Subject: [PATCH] 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 --- lib/src/tree.rs | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/lib/src/tree.rs b/lib/src/tree.rs index 57583fa01..8ca81d1c2 100644 --- a/lib/src/tree.rs +++ b/lib/src/tree.rs @@ -230,8 +230,9 @@ impl Tree { } pub struct TreeEntriesIterator<'matcher> { - tree: Pin>, entry_iterator: TreeEntriesNonRecursiveIterator<'static>, + // On drop, tree must outlive entry_iterator + tree: Pin>, subdir_iterator: Option>>, matcher: &'matcher dyn Matcher, } @@ -244,8 +245,8 @@ impl<'matcher> TreeEntriesIterator<'matcher> { let entry_iterator: TreeEntriesNonRecursiveIterator<'static> = unsafe { std::mem::transmute(entry_iterator) }; Self { - tree, entry_iterator, + tree, subdir_iterator: None, matcher, } @@ -402,11 +403,12 @@ pub fn recursive_tree_diff(root1: Tree, root2: Tree, matcher: &dyn Matcher) -> T pub struct TreeDiffIterator<'matcher> { dir: RepoPath, - tree1: Pin>, - tree2: Pin>, matcher: &'matcher dyn Matcher, // Iterator over the diffs between tree1 and tree2 entry_iterator: TreeEntryDiffIterator<'static, 'matcher>, + // On drop, tree1 and tree2 must outlive entry_iterator + tree1: Pin>, + tree2: Pin>, // 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 // for removing files in the directory. @@ -429,10 +431,10 @@ impl<'matcher> TreeDiffIterator<'matcher> { unsafe { std::mem::transmute(root_entry_iterator) }; Self { dir, - tree1, - tree2, matcher, entry_iterator: root_entry_iterator, + tree1, + tree2, added_file: None, subdir_iterator: None, }