2018-01-09 23:32:18 +03:00
|
|
|
use super::*;
|
|
|
|
|
|
|
|
pub(crate) fn use_path(p: &mut Parser) {
|
2018-01-13 11:55:03 +03:00
|
|
|
if !AnyOf(&[IDENT, SELF_KW, SUPER_KW, COLONCOLON]).is_ahead(p) {
|
2018-01-09 23:32:18 +03:00
|
|
|
return;
|
|
|
|
}
|
2018-01-12 20:59:19 +03:00
|
|
|
let mut prev = p.mark();
|
2018-01-09 23:32:18 +03:00
|
|
|
node(p, PATH, |p| {
|
2018-01-11 22:11:44 +03:00
|
|
|
path_segment(p, true);
|
2018-01-11 20:55:08 +03:00
|
|
|
});
|
|
|
|
many(p, |p| {
|
2018-01-12 20:59:19 +03:00
|
|
|
let curr = p.mark();
|
2018-01-11 20:55:08 +03:00
|
|
|
node_if(p, COLONCOLON, PATH, |p| {
|
2018-01-11 22:11:44 +03:00
|
|
|
path_segment(p, false);
|
2018-01-12 20:59:19 +03:00
|
|
|
p.forward_parent(prev, curr);
|
|
|
|
prev = curr;
|
2018-01-11 20:55:08 +03:00
|
|
|
})
|
|
|
|
});
|
2018-01-09 23:32:18 +03:00
|
|
|
}
|
|
|
|
|
2018-01-11 22:11:44 +03:00
|
|
|
fn path_segment(p: &mut Parser, first: bool) {
|
|
|
|
node(p, PATH_SEGMENT, |p| {
|
|
|
|
if first {
|
|
|
|
p.eat(COLONCOLON);
|
|
|
|
}
|
2018-01-13 11:55:03 +03:00
|
|
|
match p.current() {
|
|
|
|
IDENT | SELF_KW | SUPER_KW => {
|
|
|
|
p.bump();
|
|
|
|
},
|
|
|
|
_ => {
|
|
|
|
p.error()
|
|
|
|
.message("expected identifier")
|
|
|
|
.emit();
|
|
|
|
}
|
|
|
|
};
|
2018-01-11 22:11:44 +03:00
|
|
|
})
|
2018-01-09 23:32:18 +03:00
|
|
|
}
|