rust/tests/ui/binding/expr-match.rs
Esteban Küber 3815ed63ed Remove some unnecessary parens in assert! conditions
While working on #122661, some of these started triggering our "unnecessary parens" lints due to a change in the `assert!` desugaring. A cursory search identified a few more. Some of these have been carried from before 1.0, were a bulk rename from the previous name of `assert!` left them in that state. I went and removed as many of these unnecessary parens as possible in order to have fewer annoyances in the future if we make the lint smarter.
2025-02-06 22:28:44 +00:00

43 lines
916 B
Rust

//@ run-pass
// Tests for using match as an expression
fn test_basic() {
let mut rs: bool = match true { true => { true } false => { false } };
assert!(rs);
rs = match false { true => { false } false => { true } };
assert!(rs);
}
fn test_inferrence() {
let rs = match true { true => { true } false => { false } };
assert!(rs);
}
fn test_alt_as_alt_head() {
// Yeah, this is kind of confusing ...
let rs =
match match false { true => { true } false => { false } } {
true => { false }
false => { true }
};
assert!(rs);
}
fn test_alt_as_block_result() {
let rs =
match false {
true => { false }
false => { match true { true => { true } false => { false } } }
};
assert!(rs);
}
pub fn main() {
test_basic();
test_inferrence();
test_alt_as_alt_head();
test_alt_as_block_result();
}