diff options
| author | bors <bors@rust-lang.org> | 2014-05-23 11:46:26 -0700 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2014-05-23 11:46:26 -0700 |
| commit | c329a1fcdc6a4a2931409540c8173a112fe63395 (patch) | |
| tree | c81b663450e85bd0715f082db909d9ab4efad449 /src | |
| parent | ad775be8b48f82d19356942a4fc6fcadc56d3e7e (diff) | |
| parent | 0718259ae05e661c7f62bac6a02c6cba80d3f1f9 (diff) | |
| download | rust-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.rs | 5 | ||||
| -rw-r--r-- | src/test/run-pass/issue-14308.rs | 32 |
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); +} |
