Skip to content

Commit

Permalink
index: remove HRTB stuff by implementing RevWalkIndex for CompositeIndex
Browse files Browse the repository at this point in the history
  • Loading branch information
yuja committed Mar 11, 2024
1 parent 3d0952b commit 9c1d5d1
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 17 deletions.
28 changes: 13 additions & 15 deletions lib/src/default_index/rev_walk.rs
Original file line number Diff line number Diff line change
Expand Up @@ -40,10 +40,9 @@ pub(super) trait RevWalk<I: ?Sized> {
// to be reimplemented.

/// Reattaches the underlying `index`.
fn attach(self, index: I) -> RevWalkBorrowedIndexIter<I, Self>
fn attach(self, index: &I) -> RevWalkBorrowedIndexIter<'_, I, Self>
where
Self: Sized,
I: Sized,
{
RevWalkBorrowedIndexIter { index, walk: self }
}
Expand All @@ -52,28 +51,27 @@ pub(super) trait RevWalk<I: ?Sized> {
/// Adapter that turns `RevWalk` into `Iterator` by attaching borrowed `index`.
#[derive(Clone, Debug)]
#[must_use]
pub(super) struct RevWalkBorrowedIndexIter<I, W> {
// TODO: `index: I` will be a reference type.
index: I,
pub(super) struct RevWalkBorrowedIndexIter<'a, I: ?Sized, W> {
index: &'a I,
walk: W,
}

impl<I, W> RevWalkBorrowedIndexIter<I, W> {
impl<I: ?Sized, W> RevWalkBorrowedIndexIter<'_, I, W> {
/// Turns into `'static`-lifetime walk object by detaching the index.
pub fn detach(self) -> W {
self.walk
}
}

impl<I, W: RevWalk<I>> Iterator for RevWalkBorrowedIndexIter<I, W> {
impl<I: ?Sized, W: RevWalk<I>> Iterator for RevWalkBorrowedIndexIter<'_, I, W> {
type Item = W::Item;

fn next(&mut self) -> Option<Self::Item> {
self.walk.next(&self.index)
self.walk.next(self.index)
}
}

impl<I, W: RevWalk<I>> FusedIterator for RevWalkBorrowedIndexIter<I, W> {}
impl<I: ?Sized, W: RevWalk<I>> FusedIterator for RevWalkBorrowedIndexIter<'_, I, W> {}

/// Adapter that turns `RevWalk` into `Iterator` by attaching owned `index`.
#[derive(Clone, Debug)]
Expand All @@ -100,7 +98,7 @@ pub(super) trait RevWalkIndex {
fn adjacent_positions(&self, pos: Self::Position) -> Self::AdjacentPositions;
}

impl RevWalkIndex for &CompositeIndex {
impl RevWalkIndex for CompositeIndex {
type Position = IndexPosition;
type AdjacentPositions = SmallIndexPositionsVec;

Expand Down Expand Up @@ -383,7 +381,7 @@ impl<'a> RevWalkBuilder<'a> {
}

pub(super) type RevWalkAncestors<'a> =
RevWalkBorrowedIndexIter<&'a CompositeIndex, RevWalkImpl<IndexPosition>>;
RevWalkBorrowedIndexIter<'a, CompositeIndex, RevWalkImpl<IndexPosition>>;

#[derive(Clone)]
#[must_use]
Expand Down Expand Up @@ -420,7 +418,7 @@ impl<I: RevWalkIndex + ?Sized> RevWalk<I> for RevWalkImpl<I::Position> {
}

pub(super) type RevWalkAncestorsGenerationRange<'a> =
RevWalkBorrowedIndexIter<&'a CompositeIndex, RevWalkGenerationRangeImpl<IndexPosition>>;
RevWalkBorrowedIndexIter<'a, CompositeIndex, RevWalkGenerationRangeImpl<IndexPosition>>;
pub(super) type RevWalkDescendantsGenerationRange = RevWalkOwnedIndexIter<
RevWalkDescendantsIndex,
RevWalkGenerationRangeImpl<Reverse<IndexPosition>>,
Expand Down Expand Up @@ -540,7 +538,7 @@ impl RevWalkItemGenerationRange {

/// Walks descendants from the roots, in order of ascending index position.
pub(super) type RevWalkDescendants<'a> =
RevWalkBorrowedIndexIter<&'a CompositeIndex, RevWalkDescendantsImpl>;
RevWalkBorrowedIndexIter<'a, CompositeIndex, RevWalkDescendantsImpl>;

#[derive(Clone)]
#[must_use]
Expand All @@ -561,10 +559,10 @@ impl RevWalkDescendants<'_> {
}
}

impl RevWalk<&CompositeIndex> for RevWalkDescendantsImpl {
impl RevWalk<CompositeIndex> for RevWalkDescendantsImpl {
type Item = IndexPosition;

fn next(&mut self, index: &&CompositeIndex) -> Option<Self::Item> {
fn next(&mut self, index: &CompositeIndex) -> Option<Self::Item> {
while let Some(candidate_pos) = self.candidate_positions.pop() {
if self.root_positions.contains(&candidate_pos)
|| index
Expand Down
4 changes: 2 additions & 2 deletions lib/src/default_index/revset_engine.rs
Original file line number Diff line number Diff line change
Expand Up @@ -297,7 +297,7 @@ impl<W> fmt::Debug for RevWalkRevset<W> {

impl<W> InternalRevset for RevWalkRevset<W>
where
W: for<'index> RevWalk<&'index CompositeIndex, Item = IndexPosition> + Clone,
W: RevWalk<CompositeIndex, Item = IndexPosition> + Clone,
{
fn entries<'a, 'index: 'a>(
&'a self,
Expand All @@ -324,7 +324,7 @@ where

impl<W> ToPredicateFn for RevWalkRevset<W>
where
W: for<'index> RevWalk<&'index CompositeIndex, Item = IndexPosition> + Clone,
W: RevWalk<CompositeIndex, Item = IndexPosition> + Clone,
{
fn to_predicate_fn<'a, 'index: 'a>(
&'a self,
Expand Down

0 comments on commit 9c1d5d1

Please sign in to comment.