diff options
| author | bors <bors@rust-lang.org> | 2013-03-21 20:39:51 -0700 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2013-03-21 20:39:51 -0700 |
| commit | d52408d46a0d7f7ba0004a829207fef6870fa88c (patch) | |
| tree | ed9b12d26e44839a715c8cafd630ffa23fea7350 /src/libsyntax/parse/parser.rs | |
| parent | 5f2d4102c5dabde915f1f6cb99c38b9274790cda (diff) | |
| parent | 02c49b32caaf9ed23a347ede9ea47743717e94d7 (diff) | |
| download | rust-d52408d46a0d7f7ba0004a829207fef6870fa88c.tar.gz rust-d52408d46a0d7f7ba0004a829207fef6870fa88c.zip | |
auto merge of #5480 : pcwalton/rust/at-const, r=pcwalton
r? @catamorphism
Diffstat (limited to 'src/libsyntax/parse/parser.rs')
| -rw-r--r-- | src/libsyntax/parse/parser.rs | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs index de861075a5b..95f8afd538a 100644 --- a/src/libsyntax/parse/parser.rs +++ b/src/libsyntax/parse/parser.rs @@ -79,7 +79,7 @@ use parse::obsolete::{ObsoleteRecordType, ObsoleteRecordPattern}; use parse::obsolete::{ObsoleteAssertion, ObsoletePostFnTySigil}; use parse::obsolete::{ObsoleteBareFnType, ObsoleteNewtypeEnum}; use parse::obsolete::{ObsoleteMode, ObsoleteImplicitSelf}; -use parse::obsolete::{ObsoleteLifetimeNotation}; +use parse::obsolete::{ObsoleteLifetimeNotation, ObsoleteConstManagedPointer}; use parse::prec::{as_prec, token_to_binop}; use parse::token::{can_begin_expr, is_ident, is_ident_or_path}; use parse::token::{is_plain_ident, INTERPOLATED, special_idents}; @@ -268,6 +268,7 @@ pub struct Parser { } +#[unsafe_destructor] impl Drop for Parser { /* do not copy the parser; its state is tied to outside state */ fn finalize(&self) {} @@ -709,6 +710,9 @@ pub impl Parser { if mt.mutbl != m_imm && sigil == OwnedSigil { self.obsolete(*self.last_span, ObsoleteMutOwnedPointer); } + if mt.mutbl == m_const && sigil == ManagedSigil { + self.obsolete(*self.last_span, ObsoleteConstManagedPointer); + } ctor(mt) } @@ -1635,6 +1639,10 @@ pub impl Parser { token::AT => { self.bump(); let m = self.parse_mutability(); + if m == m_const { + self.obsolete(*self.last_span, ObsoleteConstManagedPointer); + } + let e = self.parse_prefix_expr(); hi = e.span.hi; // HACK: turn @[...] into a @-evec |
