Skip to content

Commit

Permalink
Auto merge of #26091 - chellmuth:pub-struct-field-span, r=nrc
Browse files Browse the repository at this point in the history
Issue: #26083 

Re-submitting #26084

r? @nrc
  • Loading branch information
bors committed Jun 8, 2015
2 parents 115121d + 9057272 commit 61c43b4
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 1 deletion.
5 changes: 4 additions & 1 deletion src/libsyntax/parse/parser.rs
Expand Up @@ -3394,7 +3394,10 @@ impl<'a> Parser<'a> {
/// Parse a structure field
fn parse_name_and_ty(&mut self, pr: Visibility,
attrs: Vec<Attribute> ) -> PResult<StructField> {
let lo = self.span.lo;
let lo = match pr {
Inherited => self.span.lo,
Public => self.last_span.lo,
};
if !self.token.is_plain_ident() {
return Err(self.fatal("expected ident"));
}
Expand Down
30 changes: 30 additions & 0 deletions src/test/compile-fail/pub-struct-field-span-26083.rs
@@ -0,0 +1,30 @@
// 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.

// Regression test for issue #26083
// Test that span for public struct fields start at `pub` instead of the identifier

struct Foo {
pub bar: u8,

pub
//~^ error: field `bar` is already declared [E0124]
bar: u8,

pub bar:
//~^ error: field `bar` is already declared [E0124]
u8,

bar:
//~^ error: field `bar` is already declared [E0124]
u8,
}

fn main() { }

0 comments on commit 61c43b4

Please sign in to comment.