mirror of
https://github.com/rust-lang/rust-analyzer
synced 2024-11-10 15:14:32 +00:00
Simplify fixture parsing
This commit is contained in:
parent
7cc0a86528
commit
d2fd252f9d
1 changed files with 20 additions and 21 deletions
|
@ -176,7 +176,7 @@ pub fn parse_fixture(fixture: &str) -> Vec<FixtureEntry> {
|
|||
.next()
|
||||
.expect("empty fixture");
|
||||
|
||||
let lines = fixture
|
||||
let mut lines = fixture
|
||||
.split('\n') // don't use `.lines` to not drop `\r\n`
|
||||
.filter_map(|line| {
|
||||
if line.len() >= margin {
|
||||
|
@ -189,29 +189,28 @@ pub fn parse_fixture(fixture: &str) -> Vec<FixtureEntry> {
|
|||
});
|
||||
|
||||
let mut res = Vec::new();
|
||||
let mut buf = String::new();
|
||||
let mut meta: Option<&str> = None;
|
||||
|
||||
macro_rules! flush {
|
||||
() => {
|
||||
if let Some(meta) = meta {
|
||||
res.push(FixtureEntry { meta: meta.to_string(), text: buf.clone() });
|
||||
buf.clear();
|
||||
let mut meta = None;
|
||||
loop {
|
||||
let mut next_meta = None;
|
||||
let mut text = String::new();
|
||||
for line in lines.by_ref() {
|
||||
if line.starts_with("//-") {
|
||||
next_meta = Some(line["//-".len()..].trim().to_string());
|
||||
break;
|
||||
}
|
||||
};
|
||||
};
|
||||
|
||||
for line in lines {
|
||||
if line.starts_with("//-") {
|
||||
flush!();
|
||||
buf.clear();
|
||||
meta = Some(line["//-".len()..].trim());
|
||||
continue;
|
||||
text.push_str(line);
|
||||
text.push('\n');
|
||||
}
|
||||
|
||||
if let Some(meta) = meta {
|
||||
res.push(FixtureEntry { meta, text });
|
||||
}
|
||||
meta = next_meta;
|
||||
if meta.is_none() {
|
||||
break;
|
||||
}
|
||||
buf.push_str(line);
|
||||
buf.push('\n');
|
||||
}
|
||||
flush!();
|
||||
|
||||
res
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue