Skip to content

Commit

Permalink
extended info for E0528, expected at least this-and-such many elements
Browse files Browse the repository at this point in the history
  • Loading branch information
zackmdavis committed Jul 31, 2016
1 parent 7093d1d commit e960021
Showing 1 changed file with 34 additions and 1 deletion.
35 changes: 34 additions & 1 deletion src/librustc_typeck/diagnostics.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4013,6 +4013,40 @@ match r {
```
"##,

E0528: r##"
An array or slice pattern required more elements than were present in the
matched array.
Example of erroneous code:
```compile_fail,E0528
#![feature(slice_patterns)]
let r = &[1, 2];
match r {
&[a, b, c, rest..] => { // error: pattern requires at least 3
// elements but array has 2
println!("a={}, b={}, c={} rest={:?}", a, b, c, rest);
}
}
```
Ensure that the matched array has at least as many elements as the pattern
requires. You can match an arbitrary number of remaining elements with `..`:
```
#![feature(slice_patterns)]
let r = &[1, 2, 3, 4, 5];
match r {
&[a, b, c, rest..] => { // ok!
// prints `a=1, b=2, c=3 rest=[4, 5]`
println!("a={}, b={}, c={} rest={:?}", a, b, c, rest);
}
}
```
"##,

E0529: r##"
An array or slice pattern was matched against some other type.
Expand Down Expand Up @@ -4164,6 +4198,5 @@ register_diagnostics! {
E0436, // functional record update requires a struct
E0513, // no type for local variable ..
E0521, // redundant default implementations of trait
E0528, // expected at least {} elements, found {}
E0533, // `{}` does not name a unit variant, unit struct or a constant
}

0 comments on commit e960021

Please sign in to comment.