rust/tests/ui/enum/enum-discrim-too-small2.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

38 lines
942 B
Rust
Raw Normal View History

#![deny(overflowing_literals)]
#![allow(dead_code)]
2015-12-16 17:44:15 +00:00
#[repr(i8)]
enum Ei8 {
Ai8 = 23,
Bi8 = -23,
2019-04-27 11:56:57 +00:00
Ci8 = 223, //~ ERROR literal out of range for `i8`
2015-12-16 17:44:15 +00:00
}
#[repr(i16)]
enum Ei16 {
Ai16 = 23,
Bi16 = -22333,
2019-04-27 11:56:57 +00:00
Ci16 = 55555, //~ ERROR literal out of range for `i16`
2015-12-16 17:44:15 +00:00
}
#[repr(i32)]
enum Ei32 {
Ai32 = 23,
Bi32 = -2_000_000_000,
2019-04-27 11:56:57 +00:00
Ci32 = 3_000_000_000, //~ ERROR literal out of range for `i32`
2015-12-16 17:44:15 +00:00
}
#[repr(i64)]
enum Ei64 {
Ai64 = 23,
Bi64 = -9223372036854775808,
2019-04-27 11:56:57 +00:00
Ci64 = 9223372036854775809, //~ ERROR literal out of range for `i64`
2015-12-16 17:44:15 +00:00
}
// u64 currently allows negative numbers, and i64 allows numbers greater than `1<<63`. This is a
// little counterintuitive, but since the discriminant can store all the bits, and extracting it
// with a cast requires specifying the signedness, there is no loss of information in those cases.
// This also applies to isize and usize on 64-bit targets.
pub fn main() { }