37 lines
942 B
Rust
37 lines
942 B
Rust
#![deny(overflowing_literals)]
|
|
#![allow(dead_code)]
|
|
|
|
#[repr(i8)]
|
|
enum Ei8 {
|
|
Ai8 = 23,
|
|
Bi8 = -23,
|
|
Ci8 = 223, //~ ERROR literal out of range for `i8`
|
|
}
|
|
|
|
#[repr(i16)]
|
|
enum Ei16 {
|
|
Ai16 = 23,
|
|
Bi16 = -22333,
|
|
Ci16 = 55555, //~ ERROR literal out of range for `i16`
|
|
}
|
|
|
|
#[repr(i32)]
|
|
enum Ei32 {
|
|
Ai32 = 23,
|
|
Bi32 = -2_000_000_000,
|
|
Ci32 = 3_000_000_000, //~ ERROR literal out of range for `i32`
|
|
}
|
|
|
|
#[repr(i64)]
|
|
enum Ei64 {
|
|
Ai64 = 23,
|
|
Bi64 = -9223372036854775808,
|
|
Ci64 = 9223372036854775809, //~ ERROR literal out of range for `i64`
|
|
}
|
|
|
|
// 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() { }
|