Auto merge of #26091 - chellmuth:pub-struct-field-span, r=nrc
Issue: #26083 Re-submitting https://github.com/rust-lang/rust/pull/26084 r? @nrc
This commit is contained in:
commit
61c43b4733
2 changed files with 34 additions and 1 deletions
|
@ -3394,7 +3394,10 @@ impl<'a> Parser<'a> {
|
||||||
/// Parse a structure field
|
/// Parse a structure field
|
||||||
fn parse_name_and_ty(&mut self, pr: Visibility,
|
fn parse_name_and_ty(&mut self, pr: Visibility,
|
||||||
attrs: Vec<Attribute> ) -> PResult<StructField> {
|
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() {
|
if !self.token.is_plain_ident() {
|
||||||
return Err(self.fatal("expected ident"));
|
return Err(self.fatal("expected ident"));
|
||||||
}
|
}
|
||||||
|
|
30
src/test/compile-fail/pub-struct-field-span-26083.rs
Normal file
30
src/test/compile-fail/pub-struct-field-span-26083.rs
Normal file
|
@ -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() { }
|
Loading…
Add table
Add a link
Reference in a new issue