mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-26 11:55:04 +00:00
Drop high-order stuff for good
This commit is contained in:
parent
b7ae5bbba2
commit
3630aeb1ea
2 changed files with 0 additions and 40 deletions
|
@ -46,39 +46,6 @@ fn alias(p: &mut Parser) -> bool {
|
||||||
true //FIXME: return false if three are errors
|
true //FIXME: return false if three are errors
|
||||||
}
|
}
|
||||||
|
|
||||||
fn repeat<F: FnMut(&mut Parser) -> bool>(p: &mut Parser, mut f: F) {
|
|
||||||
loop {
|
|
||||||
let pos = p.pos();
|
|
||||||
if !f(p) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if pos == p.pos() {
|
|
||||||
panic!("Infinite loop in parser")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn comma_list<F: Fn(&mut Parser) -> bool>(p: &mut Parser, end: SyntaxKind, f: F) {
|
|
||||||
repeat(p, |p| {
|
|
||||||
if p.current() == end {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
let pos = p.pos();
|
|
||||||
f(p);
|
|
||||||
if p.pos() == pos {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
if p.current() == end {
|
|
||||||
p.eat(COMMA);
|
|
||||||
} else {
|
|
||||||
p.expect(COMMA);
|
|
||||||
}
|
|
||||||
true
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
impl<'p> Parser<'p> {
|
impl<'p> Parser<'p> {
|
||||||
fn at<L: Lookahead>(&self, l: L) -> bool {
|
fn at<L: Lookahead>(&self, l: L) -> bool {
|
||||||
l.is_ahead(self)
|
l.is_ahead(self)
|
||||||
|
|
|
@ -105,9 +105,6 @@ pub(crate) struct Parser<'t> {
|
||||||
curly_limit: Option<i32>,
|
curly_limit: Option<i32>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
|
|
||||||
pub(crate) struct Pos(u32);
|
|
||||||
|
|
||||||
impl<'t> Parser<'t> {
|
impl<'t> Parser<'t> {
|
||||||
pub(crate) fn new(text: &'t str, raw_tokens: &'t [Token]) -> Parser<'t> {
|
pub(crate) fn new(text: &'t str, raw_tokens: &'t [Token]) -> Parser<'t> {
|
||||||
let mut tokens = Vec::new();
|
let mut tokens = Vec::new();
|
||||||
|
@ -133,10 +130,6 @@ impl<'t> Parser<'t> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn pos(&self) -> Pos {
|
|
||||||
Pos(self.pos as u32)
|
|
||||||
}
|
|
||||||
|
|
||||||
pub(crate) fn into_events(self) -> Vec<Event> {
|
pub(crate) fn into_events(self) -> Vec<Event> {
|
||||||
assert!(self.curly_limit.is_none());
|
assert!(self.curly_limit.is_none());
|
||||||
assert_eq!(self.current(), EOF);
|
assert_eq!(self.current(), EOF);
|
||||||
|
|
Loading…
Reference in a new issue