about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2014-05-23 11:46:26 -0700
committerbors <bors@rust-lang.org>2014-05-23 11:46:26 -0700
commitc329a1fcdc6a4a2931409540c8173a112fe63395 (patch)
treec81b663450e85bd0715f082db909d9ab4efad449 /src
parentad775be8b48f82d19356942a4fc6fcadc56d3e7e (diff)
parent0718259ae05e661c7f62bac6a02c6cba80d3f1f9 (diff)
downloadrust-c329a1fcdc6a4a2931409540c8173a112fe63395.tar.gz
rust-c329a1fcdc6a4a2931409540c8173a112fe63395.zip
auto merge of #14313 : kballard/rust/tuple_dotdot_match_ice, r=cmr
Fixes #14308.
Diffstat (limited to 'src')
-rw-r--r--src/librustc/middle/trans/_match.rs5
-rw-r--r--src/test/run-pass/issue-14308.rs32
2 files changed, 36 insertions, 1 deletions
diff --git a/src/librustc/middle/trans/_match.rs b/src/librustc/middle/trans/_match.rs
index d86d414da43..adad6cd3a70 100644
--- a/src/librustc/middle/trans/_match.rs
+++ b/src/librustc/middle/trans/_match.rs
@@ -810,6 +810,9 @@ fn enter_tuple_struct<'a, 'b>(
             ast::PatEnum(_, Some(ref elts)) => {
                 Some(elts.iter().map(|x| (*x)).collect())
             }
+            ast::PatEnum(_, None) => {
+                Some(Vec::from_elem(n_elts, dummy))
+            }
             _ => {
                 assert_is_binding_or_wild(bcx, p);
                 Some(Vec::from_elem(n_elts, dummy))
@@ -1117,7 +1120,7 @@ fn any_tuple_struct_pat(bcx: &Block, m: &[Match], col: uint) -> bool {
     m.iter().any(|br| {
         let pat = *br.pats.get(col);
         match pat.node {
-            ast::PatEnum(_, Some(_)) => {
+            ast::PatEnum(_, _) => {
                 match bcx.tcx().def_map.borrow().find(&pat.id) {
                     Some(&ast::DefFn(..)) |
                     Some(&ast::DefStruct(..)) => true,
diff --git a/src/test/run-pass/issue-14308.rs b/src/test/run-pass/issue-14308.rs
new file mode 100644
index 00000000000..0e4b4a2c9cf
--- /dev/null
+++ b/src/test/run-pass/issue-14308.rs
@@ -0,0 +1,32 @@
+// 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.
+
+struct A(int);
+struct B;
+
+fn main() {
+    let x = match A(3) {
+        A(..) => 1
+    };
+    assert_eq!(x, 1);
+    let x = match A(4) {
+        A(1) => 1,
+        A(..) => 2
+    };
+    assert_eq!(x, 2);
+
+    // This next test uses a (..) wildcard match on a nullary struct.
+    // There's no particularly good reason to support this, but it's currently allowed,
+    // and this makes sure it doesn't ICE or break LLVM.
+    let x = match B {
+        B(..) => 3
+    };
+    assert_eq!(x, 3);
+}