Skip to content

Commit

Permalink
refactor: make ErasedSegment::recursive_crawl_all return Iterator
Browse files Browse the repository at this point in the history
… instead of `Vec`
  • Loading branch information
gvozdvmozgu committed Feb 2, 2025
1 parent dbe8152 commit 955f950
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 18 deletions.
29 changes: 16 additions & 13 deletions crates/lib-core/src/parser/segments/base.rs
Original file line number Diff line number Diff line change
Expand Up @@ -172,7 +172,6 @@ impl ErasedSegment {

pub fn get_raw_segments(&self) -> Vec<ErasedSegment> {
self.recursive_crawl_all(false)
.into_iter()
.filter(|it| it.segments().is_empty())
.collect()
}
Expand Down Expand Up @@ -618,22 +617,26 @@ impl ErasedSegment {
)
}

pub fn recursive_crawl_all(&self, reverse: bool) -> Vec<ErasedSegment> {
let mut result = Vec::with_capacity(self.segments().len() + 1);
pub fn recursive_crawl_all(&self, reverse: bool) -> impl Iterator<Item = ErasedSegment> + '_ {
let self_clone = self.clone();

if reverse {
for seg in self.segments().iter().rev() {
result.append(&mut seg.recursive_crawl_all(reverse));
}
result.push(self.clone());
Box::new(
self.segments()
.iter()
.rev()
.flat_map(move |seg| seg.recursive_crawl_all(reverse))
.chain(std::iter::once(self_clone)),
) as Box<dyn Iterator<Item = _>>
} else {
result.push(self.clone());
for seg in self.segments() {
result.append(&mut seg.recursive_crawl_all(reverse));
}
Box::new(
std::iter::once(self_clone).chain(
self.segments()
.iter()
.flat_map(move |seg| seg.recursive_crawl_all(reverse)),
),
) as Box<dyn Iterator<Item = _>>
}

result
}

pub fn raw_segments_with_ancestors(&self) -> &[(ErasedSegment, Vec<PathStep>)] {
Expand Down
6 changes: 1 addition & 5 deletions crates/lib/src/rules/structure/st05.rs
Original file line number Diff line number Diff line change
Expand Up @@ -574,11 +574,7 @@ impl CTEBuilder {
clone_map: &SegmentCloneMap,
) {
for (idx, cte) in enumerate(&self.ctes) {
if cte
.recursive_crawl_all(false)
.into_iter()
.any(|seg| segment.is(&seg))
{
if cte.recursive_crawl_all(false).any(|seg| segment.is(&seg)) {
self.ctes[idx] = clone_map[&self.ctes[idx]].clone();
return;
}
Expand Down

0 comments on commit 955f950

Please sign in to comment.