use std::collections::LinkedList;
#[derive(Default)]
pub(crate) struct Argument {
pub comments_before: LinkedList<String>,
pub item: Option<rnix::SyntaxElement>,
pub comment_after: Option<String>,
}
#[derive(Default)]
pub(crate) struct Pattern {
pub initial_at: Option<rnix::SyntaxElement>,
pub comments_after_initial_at: LinkedList<String>,
pub arguments: LinkedList<Argument>,
pub comments_before_curly_b_close: LinkedList<String>,
pub comments_before_end_at: LinkedList<String>,
pub end_at: Option<rnix::SyntaxElement>,
}
pub(crate) fn parse(
build_ctx: &crate::builder::BuildCtx,
node: &rnix::SyntaxNode,
) -> Pattern {
let mut pattern = Pattern::default();
let mut children = crate::children::Children::new(build_ctx, node);
let child = children.peek_next().unwrap();
if let rnix::SyntaxKind::NODE_PAT_BIND = child.kind() {
pattern.initial_at = Some(child);
children.move_next();
}
children.drain_trivia(|element| match element {
crate::children::Trivia::Comment(text) => {
pattern.comments_after_initial_at.push_back(text);
}
crate::children::Trivia::Whitespace(_) => {}
});
children.move_next();
loop {
let mut argument = Argument::default();
loop {
let child = children.peek_next().unwrap();
match child.kind() {
rnix::SyntaxKind::NODE_PAT_ENTRY
| rnix::SyntaxKind::TOKEN_CURLY_B_CLOSE
| rnix::SyntaxKind::TOKEN_ELLIPSIS => {
break;
}
rnix::SyntaxKind::TOKEN_COMMA => {
children.move_next();
}
rnix::SyntaxKind::TOKEN_COMMENT => {
let content = child.into_token().unwrap().to_string();
argument.comments_before.push_back(content);
children.move_next();
}
rnix::SyntaxKind::TOKEN_WHITESPACE => {
children.move_next();
}
_ => {}
}
}
let child = children.peek_next().unwrap();
match child.kind() {
rnix::SyntaxKind::TOKEN_CURLY_B_CLOSE => {
pattern.comments_before_curly_b_close =
argument.comments_before;
break;
}
rnix::SyntaxKind::TOKEN_ELLIPSIS
| rnix::SyntaxKind::NODE_PAT_ENTRY => {
argument.item = Some(child);
children.move_next();
}
_ => {}
}
loop {
let child = children.peek_next().unwrap();
match child.kind() {
rnix::SyntaxKind::NODE_PAT_ENTRY
| rnix::SyntaxKind::TOKEN_ELLIPSIS
| rnix::SyntaxKind::TOKEN_CURLY_B_CLOSE => {
break;
}
rnix::SyntaxKind::TOKEN_COMMA => {
children.move_next();
}
rnix::SyntaxKind::TOKEN_COMMENT => {
let content = child.into_token().unwrap().to_string();
children.move_next();
argument.comment_after = Some(content);
break;
}
rnix::SyntaxKind::TOKEN_WHITESPACE => {
let content = child.into_token().unwrap().to_string();
children.move_next();
if crate::utils::count_newlines(&content) > 0 {
break;
}
}
_ => {}
}
}
pattern.arguments.push_back(argument);
}
children.move_next();
children.drain_trivia(|element| match element {
crate::children::Trivia::Comment(text) => {
pattern.comments_before_end_at.push_back(text);
}
crate::children::Trivia::Whitespace(_) => {}
});
if let Some(child) = children.peek_next() {
if let rnix::SyntaxKind::NODE_PAT_BIND = child.kind() {
pattern.end_at = Some(child);
}
}
pattern
}