diff options
| author | bors <bors@rust-lang.org> | 2015-01-10 08:00:09 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2015-01-10 08:00:09 +0000 |
| commit | d36dc159522ea5e587c5c7f6e4df080f063e9b48 (patch) | |
| tree | cec60404482f4d798d430c7beb2674ffcfcf70de | |
| parent | 391e0106ef46085da4998c841ffb44c115633e45 (diff) | |
| parent | cbd962ebb585732e287478169108099bcc265024 (diff) | |
| download | rust-d36dc159522ea5e587c5c7f6e4df080f063e9b48.tar.gz rust-d36dc159522ea5e587c5c7f6e4df080f063e9b48.zip | |
auto merge of #20794 : sfackler/rust/trailing-attrs, r=alexcrichton
Closes #20711
| -rw-r--r-- | src/libcore/str/mod.rs | 9 | ||||
| -rw-r--r-- | src/libsyntax/parse/parser.rs | 8 | ||||
| -rw-r--r-- | src/test/compile-fail/issue-20711-2.rs | 20 | ||||
| -rw-r--r-- | src/test/compile-fail/issue-20711.rs | 17 |
4 files changed, 49 insertions, 5 deletions
diff --git a/src/libcore/str/mod.rs b/src/libcore/str/mod.rs index 6051c68b116..94ee9b7dcf6 100644 --- a/src/libcore/str/mod.rs +++ b/src/libcore/str/mod.rs @@ -1616,13 +1616,15 @@ impl<'a> Iterator for Lines<'a> { fn next(&mut self) -> Option<&'a str> { self.inner.next() } #[inline] fn size_hint(&self) -> (uint, Option<uint>) { self.inner.size_hint() } +} -#[stable]} +#[stable] impl<'a> DoubleEndedIterator for Lines<'a> { #[inline] fn next_back(&mut self) -> Option<&'a str> { self.inner.next_back() } +} -#[stable]} +#[stable] impl<'a> Iterator for LinesAny<'a> { type Item = &'a str; @@ -1630,8 +1632,9 @@ impl<'a> Iterator for LinesAny<'a> { fn next(&mut self) -> Option<&'a str> { self.inner.next() } #[inline] fn size_hint(&self) -> (uint, Option<uint>) { self.inner.size_hint() } +} -#[stable]} +#[stable] impl<'a> DoubleEndedIterator for LinesAny<'a> { #[inline] fn next_back(&mut self) -> Option<&'a str> { self.inner.next_back() } 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) } diff --git a/src/test/compile-fail/issue-20711-2.rs b/src/test/compile-fail/issue-20711-2.rs new file mode 100644 index 00000000000..f5f5c4fe8d7 --- /dev/null +++ b/src/test/compile-fail/issue-20711-2.rs @@ -0,0 +1,20 @@ +// Copyright 2015 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +struct Foo; + +impl Foo { + fn foo() {} + + #[stable] +} //~ ERROR expected `fn`, found `}` + +fn main() {} + diff --git a/src/test/compile-fail/issue-20711.rs b/src/test/compile-fail/issue-20711.rs new file mode 100644 index 00000000000..b065355394c --- /dev/null +++ b/src/test/compile-fail/issue-20711.rs @@ -0,0 +1,17 @@ +// Copyright 2015 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +struct Foo; + +impl Foo { + #[stable] +} //~ ERROR expected `fn`, found `}` + +fn main() {} |
