diff options
| author | Alex Crichton <alex@alexcrichton.com> | 2014-10-03 07:38:29 -0700 |
|---|---|---|
| committer | Alex Crichton <alex@alexcrichton.com> | 2014-10-03 07:38:29 -0700 |
| commit | 79d0e82f7386e9525e5232bf1083f74b0385838f (patch) | |
| tree | 7e414a66d8e280177bdd0c3bfb5fa05795dd0034 /src/libsyntax | |
| parent | 61c4f6dcd95a8e0359a818c6646310272dfb3ab0 (diff) | |
| parent | da7dcee8f16b7ea635b9e0ca83b529e1d92421b0 (diff) | |
| download | rust-79d0e82f7386e9525e5232bf1083f74b0385838f.tar.gz rust-79d0e82f7386e9525e5232bf1083f74b0385838f.zip | |
rollup merge of #17729 : alexcrichton/issue-17718-start
Diffstat (limited to 'src/libsyntax')
| -rw-r--r-- | src/libsyntax/parse/parser.rs | 24 |
1 files changed, 21 insertions, 3 deletions
diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs index d2735a425f5..4c877c0b101 100644 --- a/src/libsyntax/parse/parser.rs +++ b/src/libsyntax/parse/parser.rs @@ -4732,8 +4732,7 @@ impl<'a> Parser<'a> { } } - fn parse_item_const(&mut self) -> ItemInfo { - let m = if self.eat_keyword(keywords::Mut) {MutMutable} else {MutImmutable}; + fn parse_item_const(&mut self, m: Mutability) -> ItemInfo { let id = self.parse_ident(); self.expect(&token::COLON); let ty = self.parse_ty(true); @@ -5289,7 +5288,26 @@ impl<'a> Parser<'a> { if self.is_keyword(keywords::Static) { // STATIC ITEM self.bump(); - let (ident, item_, extra_attrs) = self.parse_item_const(); + let m = if self.eat_keyword(keywords::Mut) {MutMutable} else {MutImmutable}; + let (ident, item_, extra_attrs) = self.parse_item_const(m); + let last_span = self.last_span; + let item = self.mk_item(lo, + last_span.hi, + ident, + item_, + visibility, + maybe_append(attrs, extra_attrs)); + return IoviItem(item); + } + if self.is_keyword(keywords::Const) { + // CONST ITEM + self.bump(); + if self.eat_keyword(keywords::Mut) { + let last_span = self.last_span; + self.span_err(last_span, "const globals cannot be mutable, \ + did you mean to declare a static?"); + } + let (ident, item_, extra_attrs) = self.parse_item_const(MutImmutable); let last_span = self.last_span; let item = self.mk_item(lo, last_span.hi, |
