]> git.lizzy.rs Git - rust.git/commitdiff
Warn on `pub extern crate`.
authorNick Cameron <ncameron@mozilla.com>
Fri, 18 Sep 2015 06:07:05 +0000 (18:07 +1200)
committerNick Cameron <ncameron@mozilla.com>
Fri, 18 Sep 2015 06:07:05 +0000 (18:07 +1200)
Temporary 'fix' for #26775

src/libsyntax/parse/parser.rs
src/test/compile-fail/warn-pub-extern-crate.rs [new file with mode: 0644]

index ff622859cf0b12e48b1d16f11f83c2a4436d63c8..8d50cc099bd60ae1e34e9c02335098945e95ef43 100644 (file)
@@ -5116,12 +5116,19 @@ fn parse_item_extern_crate(&mut self,
         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 (file)
index 0000000..fec0b8e
--- /dev/null
@@ -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() {
+}