about summary refs log tree commit diff
path: root/src/libsyntax
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2015-01-10 08:00:09 +0000
committerbors <bors@rust-lang.org>2015-01-10 08:00:09 +0000
commitd36dc159522ea5e587c5c7f6e4df080f063e9b48 (patch)
treecec60404482f4d798d430c7beb2674ffcfcf70de /src/libsyntax
parent391e0106ef46085da4998c841ffb44c115633e45 (diff)
parentcbd962ebb585732e287478169108099bcc265024 (diff)
downloadrust-d36dc159522ea5e587c5c7f6e4df080f063e9b48.tar.gz
rust-d36dc159522ea5e587c5c7f6e4df080f063e9b48.zip
auto merge of #20794 : sfackler/rust/trailing-attrs, r=alexcrichton
Closes #20711
Diffstat (limited to 'src/libsyntax')
-rw-r--r--src/libsyntax/parse/parser.rs8
1 files changed, 6 insertions, 2 deletions
diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs
index 531e611594a..33f9e35d8b7 100644
--- a/src/libsyntax/parse/parser.rs
+++ b/src/libsyntax/parse/parser.rs
@@ -4769,8 +4769,12 @@ impl<'a> Parser<'a> {
         self.expect(&token::OpenDelim(token::Brace));
         let (inner_attrs, mut method_attrs) =
             self.parse_inner_attrs_and_next();
-        while !self.eat(&token::CloseDelim(token::Brace)) {
+        loop {
             method_attrs.extend(self.parse_outer_attributes().into_iter());
+            if method_attrs.is_empty() && self.eat(&token::CloseDelim(token::Brace)) {
+                break;
+            }
+
             let vis = self.parse_visibility();
             if self.eat_keyword(keywords::Type) {
                 impl_items.push(TypeImplItem(P(self.parse_typedef(
@@ -4781,7 +4785,7 @@ impl<'a> Parser<'a> {
                             method_attrs,
                             vis)));
             }
-            method_attrs = self.parse_outer_attributes();
+            method_attrs = vec![];
         }
         (impl_items, inner_attrs)
     }