type param defaults

This commit is contained in:
Aleksey Kladov 2018-07-30 22:27:23 +03:00
parent 72d49c5a10
commit 27a40e0a88

View file

@ -40,6 +40,8 @@ pub(super) fn list(p: &mut Parser) {
let m = p.start(); let m = p.start();
p.bump(); p.bump();
if p.eat(COLON) { if p.eat(COLON) {
// test type_param_bounds
// struct S<T: 'a + ?Sized + (Copy)>;
loop { loop {
let has_paren = p.eat(L_PAREN); let has_paren = p.eat(L_PAREN);
p.eat(QUESTION); p.eat(QUESTION);
@ -61,7 +63,10 @@ pub(super) fn list(p: &mut Parser) {
} }
} }
} }
// test type_param_default
// struct S<T = i32>;
if p.at(EQ) { if p.at(EQ) {
p.bump();
types::type_(p) types::type_(p)
} }
m.complete(p, TYPE_PARAM); m.complete(p, TYPE_PARAM);