Improve diagnostic messages for range patterns.
This commit is contained in:
parent
448ce12bc1
commit
25d0ef347a
6 changed files with 143 additions and 67 deletions
|
|
@ -1,16 +0,0 @@
|
|||
// 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.
|
||||
|
||||
fn main() {
|
||||
match 1 {
|
||||
1...2_usize => 1, //~ ERROR mismatched types in range
|
||||
_ => 2,
|
||||
};
|
||||
}
|
||||
|
|
@ -8,22 +8,32 @@
|
|||
// option. This file may not be copied, modified, or distributed
|
||||
// except according to those terms.
|
||||
|
||||
//error-pattern: lower range bound
|
||||
//error-pattern: only char and numeric types
|
||||
//error-pattern: mismatched types
|
||||
|
||||
fn main() {
|
||||
match 5 {
|
||||
6 ... 1 => { }
|
||||
_ => { }
|
||||
6 ... 1 => { }
|
||||
_ => { }
|
||||
};
|
||||
//~^^^ ERROR lower range bound must be less than or equal to upper
|
||||
|
||||
match "wow" {
|
||||
"bar" ... "foo" => { }
|
||||
"bar" ... "foo" => { }
|
||||
};
|
||||
//~^^ ERROR only char and numeric types are allowed in range
|
||||
//~| start type: &'static str
|
||||
//~| end type: &'static str
|
||||
|
||||
match "wow" {
|
||||
10 ... "what" => ()
|
||||
};
|
||||
//~^^ ERROR only char and numeric types are allowed in range
|
||||
//~| start type: _
|
||||
//~| end type: &'static str
|
||||
|
||||
match 5 {
|
||||
'c' ... 100 => { }
|
||||
_ => { }
|
||||
'c' ... 100 => { }
|
||||
_ => { }
|
||||
};
|
||||
//~^^^ ERROR mismatched types in range
|
||||
//~| expected char
|
||||
//~| found integral variable
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue