1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
use super::RpDecl;
use std::collections::LinkedList;
#[derive(Debug, Clone, Serialize)]
pub struct RpFile {
pub comment: Vec<String>,
pub decls: Vec<RpDecl>,
}
#[allow(linkedlist)]
pub struct ForEachDecl<'a> {
queue: LinkedList<&'a RpDecl>,
}
impl<'a> Iterator for ForEachDecl<'a> {
type Item = &'a RpDecl;
fn next(&mut self) -> Option<Self::Item> {
if let Some(decl) = self.queue.pop_front() {
self.queue.extend(decl.decls());
Some(decl)
} else {
None
}
}
}
impl RpFile {
pub fn for_each_decl(&self) -> ForEachDecl {
let mut queue = LinkedList::new();
queue.extend(self.decls.iter());
ForEachDecl { queue: queue }
}
}