mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 13:48:50 +00:00
internal: add tests for extra parser entry points
This commit is contained in:
parent
355a4bdb88
commit
3f5fc05d66
4 changed files with 46 additions and 1 deletions
|
@ -22,6 +22,7 @@ pub struct Output {
|
||||||
error: Vec<String>,
|
error: Vec<String>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Debug)]
|
||||||
pub enum Step<'a> {
|
pub enum Step<'a> {
|
||||||
Token { kind: SyntaxKind, n_input_tokens: u8 },
|
Token { kind: SyntaxKind, n_input_tokens: u8 },
|
||||||
Enter { kind: SyntaxKind },
|
Enter { kind: SyntaxKind },
|
||||||
|
|
|
@ -16,6 +16,7 @@ use crate::{
|
||||||
SyntaxKind::{self, *},
|
SyntaxKind::{self, *},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#[derive(Debug)]
|
||||||
pub enum StrStep<'a> {
|
pub enum StrStep<'a> {
|
||||||
Token { kind: SyntaxKind, text: &'a str },
|
Token { kind: SyntaxKind, text: &'a str },
|
||||||
Enter { kind: SyntaxKind },
|
Enter { kind: SyntaxKind },
|
||||||
|
@ -75,7 +76,8 @@ impl<'a> LexedStr<'a> {
|
||||||
builder.eat_trivias();
|
builder.eat_trivias();
|
||||||
(builder.sink)(StrStep::Exit);
|
(builder.sink)(StrStep::Exit);
|
||||||
}
|
}
|
||||||
State::PendingEnter | State::Normal => unreachable!(),
|
State::PendingEnter => (),
|
||||||
|
State::Normal => unreachable!(),
|
||||||
}
|
}
|
||||||
|
|
||||||
let is_eof = builder.pos == builder.lexed.len();
|
let is_eof = builder.pos == builder.lexed.len();
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
mod sourcegen_inline_tests;
|
mod sourcegen_inline_tests;
|
||||||
|
mod entries;
|
||||||
|
|
||||||
use std::{
|
use std::{
|
||||||
fmt::Write,
|
fmt::Write,
|
||||||
|
|
41
crates/parser/src/tests/entries.rs
Normal file
41
crates/parser/src/tests/entries.rs
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
use crate::{LexedStr, PrefixEntryPoint, StrStep};
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn vis() {
|
||||||
|
check_prefix(PrefixEntryPoint::Vis, "pub(crate) fn foo() {}", "pub(crate)");
|
||||||
|
check_prefix(PrefixEntryPoint::Vis, "fn foo() {}", "");
|
||||||
|
check_prefix(PrefixEntryPoint::Vis, "pub(fn foo() {}", "pub");
|
||||||
|
check_prefix(PrefixEntryPoint::Vis, "pub(crate fn foo() {}", "pub(crate");
|
||||||
|
check_prefix(PrefixEntryPoint::Vis, "crate fn foo() {}", "crate");
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn block() {
|
||||||
|
check_prefix(PrefixEntryPoint::Block, "{}, 92", "{}");
|
||||||
|
check_prefix(PrefixEntryPoint::Block, "{, 92)", "{, 92)");
|
||||||
|
check_prefix(PrefixEntryPoint::Block, "()", "");
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn stmt() {
|
||||||
|
check_prefix(PrefixEntryPoint::Stmt, "92; fn", "92");
|
||||||
|
check_prefix(PrefixEntryPoint::Stmt, "let _ = 92; 1", "let _ = 92");
|
||||||
|
check_prefix(PrefixEntryPoint::Stmt, "pub fn f() {} = 92", "pub fn f() {}");
|
||||||
|
check_prefix(PrefixEntryPoint::Stmt, ";;;", ";");
|
||||||
|
check_prefix(PrefixEntryPoint::Stmt, "+", "+");
|
||||||
|
check_prefix(PrefixEntryPoint::Stmt, "@", "@");
|
||||||
|
check_prefix(PrefixEntryPoint::Stmt, "loop {} - 1", "loop {}");
|
||||||
|
}
|
||||||
|
|
||||||
|
fn check_prefix(entry: PrefixEntryPoint, input: &str, prefix: &str) {
|
||||||
|
let lexed = LexedStr::new(input);
|
||||||
|
let input = lexed.to_input();
|
||||||
|
let output = entry.parse(&input);
|
||||||
|
|
||||||
|
let mut buf = String::new();
|
||||||
|
lexed.intersperse_trivia(&output, &mut |step| match step {
|
||||||
|
StrStep::Token { kind: _, text } => buf.push_str(text),
|
||||||
|
_ => (),
|
||||||
|
});
|
||||||
|
assert_eq!(buf.trim(), prefix)
|
||||||
|
}
|
Loading…
Reference in a new issue