// revisions: noopt opt opt_with_overflow_checks //[noopt]compile-flags: -C opt-level=0 //[opt]compile-flags: -O //[opt_with_overflow_checks]compile-flags: -C overflow-checks=on -O #![crate_type="lib"] pub trait Foo { const NEG: i32; const NEG_REV: i32; const ADD: i32; const ADD_REV: i32; const DIV: i32; const DIV_REV: i32; const OOB: i32; const OOB_REV: i32; } // These constants cannot be evaluated already (they depend on `T::N`), so they can just be linted // like normal run-time code. But codegen works a bit different in const context, so this test // makes sure that we still catch overflow. Also make sure we emit the same lints if we reverse the // operands (so that the generic operand comes first). impl Foo for Vec { const NEG: i32 = -i32::MIN + T::NEG; //~^ ERROR arithmetic operation will overflow const NEG_REV: i32 = T::NEG + (-i32::MIN); //~^ ERROR arithmetic operation will overflow const ADD: i32 = (i32::MAX+1) + T::ADD; //~^ ERROR arithmetic operation will overflow const ADD_REV: i32 = T::ADD + (i32::MAX+1); //~^ ERROR arithmetic operation will overflow const DIV: i32 = (1/0) + T::DIV; //~^ ERROR operation will panic const DIV_REV: i32 = T::DIV + (1/0); //~^ ERROR operation will panic const OOB: i32 = [1][1] + T::OOB; //~^ ERROR operation will panic const OOB_REV: i32 = T::OOB + [1][1]; //~^ ERROR operation will panic }