about summary refs log tree commit diff
diff options
context:
space:
mode:
authorJakub Wieczorek <jakub@jakub.cc>2014-10-11 17:46:45 +0200
committerJakub Wieczorek <jakub@jakub.cc>2014-10-12 11:11:50 +0200
commitfdc1eeac622241d7d1f89c1370f71fb1990bdb16 (patch)
treefe69390cde8073940b408626b242f8bb4e8d453d
parent86509d8d7ab68c5e4202dea9ff1bfb79409f2f8d (diff)
downloadrust-fdc1eeac622241d7d1f89c1370f71fb1990bdb16.tar.gz
rust-fdc1eeac622241d7d1f89c1370f71fb1990bdb16.zip
Make the diagnostic for static variables in patterns better
Fixes #17933.
-rw-r--r--src/librustc/middle/resolve.rs9
-rw-r--r--src/test/compile-fail/issue-17933.rs19
2 files changed, 26 insertions, 2 deletions
diff --git a/src/librustc/middle/resolve.rs b/src/librustc/middle/resolve.rs
index d40c252d5f5..298b8088770 100644
--- a/src/librustc/middle/resolve.rs
+++ b/src/librustc/middle/resolve.rs
@@ -5112,10 +5112,15 @@ impl<'a> Resolver<'a> {
                         Some(def @ (DefFn(..), _))      |
                         Some(def @ (DefVariant(..), _)) |
                         Some(def @ (DefStruct(..), _))  |
-                        Some(def @ (DefConst(..), _))  |
-                        Some(def @ (DefStatic(..), _)) => {
+                        Some(def @ (DefConst(..), _)) => {
                             self.record_def(pattern.id, def);
                         }
+                        Some((DefStatic(..), _)) => {
+                            self.resolve_error(path.span,
+                                               "static variables cannot be \
+                                                referenced in a pattern, \
+                                                use a `const` instead");
+                        }
                         Some(_) => {
                             self.resolve_error(path.span,
                                 format!("`{}` is not an enum variant, struct or const",
diff --git a/src/test/compile-fail/issue-17933.rs b/src/test/compile-fail/issue-17933.rs
new file mode 100644
index 00000000000..de5a38507bc
--- /dev/null
+++ b/src/test/compile-fail/issue-17933.rs
@@ -0,0 +1,19 @@
+// Copyright 2014 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.
+
+pub static X: uint = 1u;
+
+fn main() {
+    match 1u {
+        self::X => { },
+        //~^ ERROR static variables cannot be referenced in a pattern, use a `const` instead
+        _       => { },
+    }
+}