2013-05-22 05:54:35 -05:00
|
|
|
// Test that we do not permit moves from &[] matched by a vec pattern.
|
|
|
|
|
2013-07-02 14:47:32 -05:00
|
|
|
#[deriving(Clone)]
|
2013-05-22 05:54:35 -05:00
|
|
|
struct Foo {
|
|
|
|
string: ~str
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn main() {
|
Fix incorrect non-exhaustive matching for fixed length vecs
Code like this is fixed now:
```
fn foo(p: [u8, ..4]) {
match p {
[a, b, c, d] => {}
};
}
```
Invalid constructors are not reported as errors yet:
```
fn foo(p: [u8, ..4]) {
match p {
[_, _, _] => {} // this should be error
[_, _, _, _, _, .._] => {} // and this
_ => {}
}
}
```
Issue #8311 is partially fixed by this commit. Fixed-length arrays in
let statement are not yet allowed:
```
let [a, b, c] = [1, 2, 3]; // still fails
```
2013-08-07 13:07:24 -05:00
|
|
|
let x = ~[
|
2013-05-22 05:54:35 -05:00
|
|
|
Foo { string: ~"foo" },
|
|
|
|
Foo { string: ~"bar" },
|
|
|
|
Foo { string: ~"baz" }
|
|
|
|
];
|
|
|
|
match x {
|
2013-06-20 14:11:20 -05:00
|
|
|
[_, ..tail] => {
|
2013-05-22 05:54:35 -05:00
|
|
|
match tail {
|
|
|
|
[Foo { string: a }, Foo { string: b }] => {
|
|
|
|
//~^ ERROR cannot move out of dereference of & pointer
|
|
|
|
//~^^ ERROR cannot move out of dereference of & pointer
|
|
|
|
}
|
|
|
|
_ => {
|
2013-09-19 00:04:03 -05:00
|
|
|
unreachable!();
|
2013-05-22 05:54:35 -05:00
|
|
|
}
|
|
|
|
}
|
2013-07-02 14:47:32 -05:00
|
|
|
let z = tail[0].clone();
|
2013-09-29 22:06:21 -05:00
|
|
|
info2!("{:?}", z);
|
2013-05-22 05:54:35 -05:00
|
|
|
}
|
|
|
|
_ => {
|
2013-09-19 00:04:03 -05:00
|
|
|
unreachable!();
|
2013-05-22 05:54:35 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|