From 8fdf9db6e01dc3da0332275fe99a61441114e79a Mon Sep 17 00:00:00 2001 From: Yuya Nishihara Date: Thu, 7 Dec 2023 20:49:17 +0900 Subject: [PATCH] revset: remove 'index lifetime from InternalRevset --- lib/src/default_revset_engine.rs | 110 ++++++++++++------------------- 1 file changed, 41 insertions(+), 69 deletions(-) diff --git a/lib/src/default_revset_engine.rs b/lib/src/default_revset_engine.rs index f268a09dcf..3e91ab37ca 100644 --- a/lib/src/default_revset_engine.rs +++ b/lib/src/default_revset_engine.rs @@ -57,15 +57,12 @@ impl ToPredicateFn for Box { } } -// TODO: move <'index> parameter to iter<'a, 'index: 'a> -trait InternalRevset<'index>: fmt::Debug + ToPredicateFn { +trait InternalRevset: fmt::Debug + ToPredicateFn { // All revsets currently iterate in order of descending index position - fn iter<'a>( + fn iter<'a, 'index: 'a>( &'a self, index: CompositeIndex<'index>, - ) -> Box> + 'a> - where - 'index: 'a; + ) -> Box> + 'a>; fn into_predicate<'a>(self: Box) -> Box where @@ -73,15 +70,12 @@ trait InternalRevset<'index>: fmt::Debug + ToPredicateFn { } pub struct RevsetImpl<'index> { - inner: Box + 'index>, + inner: Box, index: CompositeIndex<'index>, } impl<'index> RevsetImpl<'index> { - fn new( - revset: Box + 'index>, - index: CompositeIndex<'index>, - ) -> Self { + fn new(revset: Box, index: CompositeIndex<'index>) -> Self { Self { inner: revset, index, @@ -187,14 +181,11 @@ impl EagerRevset { } } -impl<'index> InternalRevset<'index> for EagerRevset { - fn iter<'a>( +impl InternalRevset for EagerRevset { + fn iter<'a, 'index: 'a>( &'a self, index: CompositeIndex<'index>, - ) -> Box> + 'a> - where - 'index: 'a, - { + ) -> Box> + 'a> { let entries = self .positions .iter() @@ -248,17 +239,14 @@ impl fmt::Debug for RevWalkRevset { } } -impl<'index, F> InternalRevset<'index> for RevWalkRevset +impl InternalRevset for RevWalkRevset where F: Fn(CompositeIndex<'_>) -> Box> + '_>, { - fn iter<'a>( + fn iter<'a, 'index: 'a>( &'a self, index: CompositeIndex<'index>, - ) -> Box> + 'a> - where - 'index: 'a, - { + ) -> Box> + 'a> { (self.walk)(index) } @@ -301,19 +289,16 @@ fn predicate_fn_from_positions<'iter>( } #[derive(Debug)] -struct FilterRevset<'index, P> { - candidates: Box + 'index>, +struct FilterRevset

{ + candidates: Box, predicate: P, } -impl<'index, P: ToPredicateFn> InternalRevset<'index> for FilterRevset<'index, P> { - fn iter<'a>( +impl InternalRevset for FilterRevset

{ + fn iter<'a, 'index: 'a>( &'a self, index: CompositeIndex<'index>, - ) -> Box> + 'a> - where - 'index: 'a, - { + ) -> Box> + 'a> { let p = self.predicate.to_predicate_fn(index); Box::new(self.candidates.iter(index).filter(p)) } @@ -326,7 +311,7 @@ impl<'index, P: ToPredicateFn> InternalRevset<'index> for FilterRevset<'index, P } } -impl ToPredicateFn for FilterRevset<'_, P> { +impl ToPredicateFn for FilterRevset

{ fn to_predicate_fn<'a, 'index: 'a>( &'a self, index: CompositeIndex<'index>, @@ -351,19 +336,16 @@ impl ToPredicateFn for NotInPredicate { } #[derive(Debug)] -struct UnionRevset<'index> { - set1: Box + 'index>, - set2: Box + 'index>, +struct UnionRevset { + set1: Box, + set2: Box, } -impl<'index> InternalRevset<'index> for UnionRevset<'index> { - fn iter<'a>( +impl InternalRevset for UnionRevset { + fn iter<'a, 'index: 'a>( &'a self, index: CompositeIndex<'index>, - ) -> Box> + 'a> - where - 'index: 'a, - { + ) -> Box> + 'a> { Box::new(UnionRevsetIterator { iter1: self.set1.iter(index).peekable(), iter2: self.set2.iter(index).peekable(), @@ -378,7 +360,7 @@ impl<'index> InternalRevset<'index> for UnionRevset<'index> { } } -impl ToPredicateFn for UnionRevset<'_> { +impl ToPredicateFn for UnionRevset { fn to_predicate_fn<'a, 'index: 'a>( &'a self, index: CompositeIndex<'index>, @@ -441,19 +423,16 @@ impl<'index, I1: Iterator>, I2: Iterator { - set1: Box + 'index>, - set2: Box + 'index>, +struct IntersectionRevset { + set1: Box, + set2: Box, } -impl<'index> InternalRevset<'index> for IntersectionRevset<'index> { - fn iter<'a>( +impl InternalRevset for IntersectionRevset { + fn iter<'a, 'index: 'a>( &'a self, index: CompositeIndex<'index>, - ) -> Box> + 'a> - where - 'index: 'a, - { + ) -> Box> + 'a> { Box::new(IntersectionRevsetIterator { iter1: self.set1.iter(index).peekable(), iter2: self.set2.iter(index).peekable(), @@ -468,7 +447,7 @@ impl<'index> InternalRevset<'index> for IntersectionRevset<'index> { } } -impl ToPredicateFn for IntersectionRevset<'_> { +impl ToPredicateFn for IntersectionRevset { fn to_predicate_fn<'a, 'index: 'a>( &'a self, index: CompositeIndex<'index>, @@ -520,21 +499,18 @@ impl<'index, I1: Iterator>, I2: Iterator { +struct DifferenceRevset { // The minuend (what to subtract from) - set1: Box + 'index>, + set1: Box, // The subtrahend (what to subtract) - set2: Box + 'index>, + set2: Box, } -impl<'index> InternalRevset<'index> for DifferenceRevset<'index> { - fn iter<'a>( +impl InternalRevset for DifferenceRevset { + fn iter<'a, 'index: 'a>( &'a self, index: CompositeIndex<'index>, - ) -> Box> + 'a> - where - 'index: 'a, - { + ) -> Box> + 'a> { Box::new(DifferenceRevsetIterator { iter1: self.set1.iter(index).peekable(), iter2: self.set2.iter(index).peekable(), @@ -549,7 +525,7 @@ impl<'index> InternalRevset<'index> for DifferenceRevset<'index> { } } -impl ToPredicateFn for DifferenceRevset<'_> { +impl ToPredicateFn for DifferenceRevset { fn to_predicate_fn<'a, 'index: 'a>( &'a self, index: CompositeIndex<'index>, @@ -633,7 +609,7 @@ impl<'index> EvaluationContext<'index> { fn evaluate( &self, expression: &ResolvedExpression, - ) -> Result + 'index>, RevsetEvaluationError> { + ) -> Result, RevsetEvaluationError> { let index = self.index; match expression { ResolvedExpression::Commits(commit_ids) => { @@ -817,7 +793,7 @@ impl<'index> EvaluationContext<'index> { fn evaluate_predicate( &self, expression: &ResolvedPredicateExpression, - ) -> Result, RevsetEvaluationError> { + ) -> Result, RevsetEvaluationError> { match expression { ResolvedPredicateExpression::Filter(predicate) => { Ok(build_predicate_fn(self.store.clone(), predicate)) @@ -847,11 +823,7 @@ impl<'index> EvaluationContext<'index> { EagerRevset { positions } } - fn take_latest_revset( - &self, - candidate_set: &dyn InternalRevset<'index>, - count: usize, - ) -> EagerRevset { + fn take_latest_revset(&self, candidate_set: &dyn InternalRevset, count: usize) -> EagerRevset { if count == 0 { return EagerRevset::empty(); }