about summary refs log tree commit diff
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2015-11-03 15:19:07 +0000
committerbors <bors@rust-lang.org>2015-11-03 15:19:07 +0000
commit4aa1f59e1eddbef7d85f7c4c9606f3941036c541 (patch)
tree1ff30e75bd3b49331754454428d1b1493056f931
parentc143ae7764a4bedc61c6c9d86803af940f813a58 (diff)
parent6468292c35d3ca556decce809d1b79c4f8b250e2 (diff)
downloadrust-4aa1f59e1eddbef7d85f7c4c9606f3941036c541.tar.gz
rust-4aa1f59e1eddbef7d85f7c4c9606f3941036c541.zip
Auto merge of #29515 - Manishearth:ice-itembody, r=eddyb
r? @eddyb or @nrc
-rw-r--r--src/librustc/middle/mem_categorization.rs13
-rw-r--r--src/test/compile-fail/issue-28971.rs27
2 files changed, 39 insertions, 1 deletions
diff --git a/src/librustc/middle/mem_categorization.rs b/src/librustc/middle/mem_categorization.rs
index 00bd850ea62..d8031e3134d 100644
--- a/src/librustc/middle/mem_categorization.rs
+++ b/src/librustc/middle/mem_categorization.rs
@@ -1195,7 +1195,18 @@ impl<'t, 'a,'tcx> MemCategorizationContext<'t, 'a, 'tcx> {
 
         (*op)(self, cmt.clone(), pat);
 
-        let opt_def = self.tcx().def_map.borrow().get(&pat.id).map(|d| d.full_def());
+        let opt_def = if let Some(path_res) = self.tcx().def_map.borrow().get(&pat.id) {
+            if path_res.depth != 0 {
+                // Since patterns can be associated constants
+                // which are resolved during typeck, we might have
+                // some unresolved patterns reaching this stage
+                // without aborting
+                return Err(());
+            }
+            Some(path_res.full_def())
+        } else {
+            None
+        };
 
         // Note: This goes up here (rather than within the PatEnum arm
         // alone) because struct patterns can refer to struct types or
diff --git a/src/test/compile-fail/issue-28971.rs b/src/test/compile-fail/issue-28971.rs
new file mode 100644
index 00000000000..1d14b71a40e
--- /dev/null
+++ b/src/test/compile-fail/issue-28971.rs
@@ -0,0 +1,27 @@
+// Copyright 2012-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.
+
+// This should not cause an ICE
+
+enum Foo {
+    Bar(u8)
+}
+fn main(){
+    foo(|| {
+        match Foo::Bar(1) {
+            Foo::Baz(..) => (), //~ ERROR no associated
+            _ => (),
+        }
+    });
+}
+
+fn foo<F>(f: F) where F: FnMut() {
+    f();
+}