mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-02 07:22:42 +00:00
Better diagnostics and recovery for const
in extern blocks
This commit is contained in:
parent
ff0513c697
commit
a965beef8f
@ -5518,12 +5518,11 @@ impl<'a> Parser<'a> {
|
||||
})
|
||||
}
|
||||
|
||||
/// Parse a static item from a foreign module
|
||||
/// Parse a static item from a foreign module.
|
||||
/// Assumes that the `static` keyword is already parsed.
|
||||
fn parse_item_foreign_static(&mut self, vis: ast::Visibility, lo: Span, attrs: Vec<Attribute>)
|
||||
-> PResult<'a, ForeignItem> {
|
||||
self.expect_keyword(keywords::Static)?;
|
||||
let mutbl = self.eat_keyword(keywords::Mut);
|
||||
|
||||
let ident = self.parse_ident()?;
|
||||
self.expect(&token::Colon)?;
|
||||
let ty = self.parse_ty()?;
|
||||
@ -5997,21 +5996,22 @@ impl<'a> Parser<'a> {
|
||||
let lo = self.span;
|
||||
let visibility = self.parse_visibility(false)?;
|
||||
|
||||
if self.check_keyword(keywords::Static) {
|
||||
// FOREIGN STATIC ITEM
|
||||
// FOREIGN STATIC ITEM
|
||||
// Treat `const` as `static` for error recovery, but don't add it to expected tokens.
|
||||
if self.check_keyword(keywords::Static) || self.token.is_keyword(keywords::Const) {
|
||||
if self.token.is_keyword(keywords::Const) {
|
||||
self.diagnostic()
|
||||
.struct_span_err(self.span, "extern items cannot be `const`")
|
||||
.span_label(self.span, "use `static` instead").emit();
|
||||
}
|
||||
self.bump(); // `static` or `const`
|
||||
return Ok(Some(self.parse_item_foreign_static(visibility, lo, attrs)?));
|
||||
}
|
||||
// FOREIGN FUNCTION ITEM
|
||||
if self.check_keyword(keywords::Fn) {
|
||||
// FOREIGN FUNCTION ITEM
|
||||
return Ok(Some(self.parse_item_foreign_fn(visibility, lo, attrs)?));
|
||||
}
|
||||
|
||||
if self.check_keyword(keywords::Const) {
|
||||
let mut err = self.span_fatal(self.span, "extern items cannot be `const`");
|
||||
err.help("use `static` instead");
|
||||
return Err(err);
|
||||
}
|
||||
|
||||
// FIXME #5668: this will occur for a macro invocation:
|
||||
match self.parse_macro_use_or_failure(attrs, true, false, lo, visibility)? {
|
||||
Some(item) => {
|
||||
|
19
src/test/ui/extern-const.rs
Normal file
19
src/test/ui/extern-const.rs
Normal file
@ -0,0 +1,19 @@
|
||||
// Copyright 2017 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.
|
||||
|
||||
// compile-flags: -Z continue-parse-after-error
|
||||
|
||||
extern "C" {
|
||||
const C: u8; //~ ERROR extern items cannot be `const`
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let x = C;
|
||||
}
|
8
src/test/ui/extern-const.stderr
Normal file
8
src/test/ui/extern-const.stderr
Normal file
@ -0,0 +1,8 @@
|
||||
error: extern items cannot be `const`
|
||||
--> $DIR/extern-const.rs:14:5
|
||||
|
|
||||
14 | const C: u8; //~ ERROR extern items cannot be `const`
|
||||
| ^^^^^ use `static` instead
|
||||
|
||||
error: aborting due to previous error
|
||||
|
Loading…
Reference in New Issue
Block a user