diff options
| author | bors <bors@rust-lang.org> | 2015-09-19 04:51:13 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2015-09-19 04:51:13 +0000 |
| commit | d97be7bd70903350e75c6ae9ca41a92aa3a5e362 (patch) | |
| tree | a72fc2227dc7bc12399191689f92210d281f4b96 | |
| parent | 2915f891673f9c8c8be3cc06aeb3bebf7df66115 (diff) | |
| parent | 269c59d3414027c2194fb5deb1d26845d088afb9 (diff) | |
| download | rust-d97be7bd70903350e75c6ae9ca41a92aa3a5e362.tar.gz rust-d97be7bd70903350e75c6ae9ca41a92aa3a5e362.zip | |
Auto merge of #28486 - nrc:pub-extern-crate, r=alexcrichton
Temporary 'fix' for #26775 r? @brson
| -rw-r--r-- | src/libsyntax/parse/parser.rs | 17 | ||||
| -rw-r--r-- | src/test/compile-fail/warn-pub-extern-crate.rs | 18 |
2 files changed, 30 insertions, 5 deletions
diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs index 87500142ccd..7f57170c2ef 100644 --- a/src/libsyntax/parse/parser.rs +++ b/src/libsyntax/parse/parser.rs @@ -5101,12 +5101,19 @@ impl<'a> Parser<'a> { try!(self.expect(&token::Semi)); let last_span = self.last_span; + + if visibility == ast::Public { + self.span_warn(mk_sp(lo, last_span.hi), + "`pub extern crate` does not work as expected and should not be used. \ + Likely to become an error. Prefer `extern crate` and `pub use`."); + } + Ok(self.mk_item(lo, - last_span.hi, - ident, - ItemExternCrate(maybe_path), - visibility, - attrs)) + last_span.hi, + ident, + ItemExternCrate(maybe_path), + visibility, + attrs)) } /// Parse `extern` for foreign ABIs diff --git a/src/test/compile-fail/warn-pub-extern-crate.rs b/src/test/compile-fail/warn-pub-extern-crate.rs new file mode 100644 index 00000000000..fec0b8e1a4c --- /dev/null +++ b/src/test/compile-fail/warn-pub-extern-crate.rs @@ -0,0 +1,18 @@ +// 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. + +// Check that `pub extern crate` gives a warning. + + +pub extern crate core; //~WARN `pub extern crate` does not work +//~^ ERROR core + +fn main() { +} |
