1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
|
//@ check-pass
// Issue #7526: lowercase static constants in patterns look like bindings
// This is similar to lint-lowercase-static-const-pattern.rs, except it
// shows the expected usual workaround (choosing a different name for
// the static definition) and also demonstrates that one can work
// around this problem locally by renaming the constant in the `use`
// form to an uppercase identifier that placates the lint.
#![deny(non_upper_case_globals)]
pub const A : isize = 97;
fn f() {
let r = match (0,0) {
(0, A) => 0,
(x, y) => 1 + x + y,
};
assert_eq!(r, 1);
let r = match (0,97) {
(0, A) => 0,
(x, y) => 1 + x + y,
};
assert_eq!(r, 0);
}
mod m {
#[allow(non_upper_case_globals)]
pub const aha : isize = 7;
}
fn g() {
use self::m::aha as AHA;
let r = match (0,0) {
(0, AHA) => 0,
(x, y) => 1 + x + y,
};
assert_eq!(r, 1);
let r = match (0,7) {
(0, AHA) => 0,
(x, y) => 1 + x + y,
};
assert_eq!(r, 0);
}
fn h() {
let r = match (0,0) {
(0, self::m::aha) => 0,
(x, y) => 1 + x + y,
};
assert_eq!(r, 1);
let r = match (0,7) {
(0, self::m::aha) => 0,
(x, y) => 1 + x + y,
};
assert_eq!(r, 0);
}
pub fn main () {
f();
g();
h();
}
|