rust/tests/ui/numbers-arithmetic/overflowing-lsh-4.rs

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

25 lines
902 B
Rust
Raw Normal View History

2020-04-16 01:50:32 -05:00
// build-fail
// compile-flags: -C debug-assertions
// This function is checking that our automatic truncation does not
// sidestep the overflow checking.
2022-09-21 06:05:20 -05:00
#![deny(arithmetic_overflow)]
fn main() {
// this signals overflow when checking is on
let x = 1_i8 << 17;
2020-04-16 01:50:32 -05:00
//~^ ERROR: this arithmetic operation will overflow
// ... but when checking is off, the fallback will truncate the
// input to its lower three bits (= 1). Note that this is *not*
// the behavior of the x86 processor for 8- and 16-bit types,
// but it is necessary to avoid undefined behavior from LLVM.
//
// We check that here, by ensuring the result has only been
// shifted by one place; if overflow checking is turned off, then
// this assertion will pass (and the compiletest driver will
// report that the test did not produce the error expected above).
assert_eq!(x, 2_i8);
}