diff options
Diffstat (limited to 'src/parser')
-rw-r--r-- | src/parser/grammar/items/mod.rs | 5 | ||||
-rw-r--r-- | src/parser/grammar/mod.rs | 12 |
2 files changed, 14 insertions, 3 deletions
diff --git a/src/parser/grammar/items/mod.rs b/src/parser/grammar/items/mod.rs index ffe86fa97..d671568b1 100644 --- a/src/parser/grammar/items/mod.rs +++ b/src/parser/grammar/items/mod.rs | |||
@@ -196,8 +196,9 @@ fn extern_crate_item(p: &mut Parser) { | |||
196 | p.bump(); | 196 | p.bump(); |
197 | assert!(p.at(CRATE_KW)); | 197 | assert!(p.at(CRATE_KW)); |
198 | p.bump(); | 198 | p.bump(); |
199 | 199 | name(p); | |
200 | p.expect(IDENT) && alias(p) && p.expect(SEMI); | 200 | alias(p); |
201 | p.expect(SEMI); | ||
201 | } | 202 | } |
202 | 203 | ||
203 | fn extern_block(p: &mut Parser) { | 204 | fn extern_block(p: &mut Parser) { |
diff --git a/src/parser/grammar/mod.rs b/src/parser/grammar/mod.rs index b949583ff..6e82d7c69 100644 --- a/src/parser/grammar/mod.rs +++ b/src/parser/grammar/mod.rs | |||
@@ -44,12 +44,22 @@ fn alias(p: &mut Parser) -> bool { | |||
44 | if p.at(AS_KW) { | 44 | if p.at(AS_KW) { |
45 | let alias = p.start(); | 45 | let alias = p.start(); |
46 | p.bump(); | 46 | p.bump(); |
47 | p.expect(IDENT); | 47 | name(p); |
48 | alias.complete(p, ALIAS); | 48 | alias.complete(p, ALIAS); |
49 | } | 49 | } |
50 | true //FIXME: return false if three are errors | 50 | true //FIXME: return false if three are errors |
51 | } | 51 | } |
52 | 52 | ||
53 | fn name(p: &mut Parser) { | ||
54 | if p.at(IDENT) { | ||
55 | let m = p.start(); | ||
56 | p.bump(); | ||
57 | m.complete(p, NAME); | ||
58 | } else { | ||
59 | p.error("expected a name"); | ||
60 | } | ||
61 | } | ||
62 | |||
53 | fn error_block(p: &mut Parser, message: &str) { | 63 | fn error_block(p: &mut Parser, message: &str) { |
54 | assert!(p.at(L_CURLY)); | 64 | assert!(p.at(L_CURLY)); |
55 | let err = p.start(); | 65 | let err = p.start(); |