2024-03-13 09:07:47 -05:00
|
|
|
//@revisions: noopt opt
|
2024-03-15 15:06:40 -05:00
|
|
|
//@ build-fail
|
2024-03-18 11:54:48 -05:00
|
|
|
//@[noopt] compile-flags: -Copt-level=0
|
2024-03-13 09:07:47 -05:00
|
|
|
//@[opt] compile-flags: -O
|
2024-03-17 03:02:18 -05:00
|
|
|
//! This fails without optimizations, so it should also fail with optimizations.
|
2024-03-13 09:07:47 -05:00
|
|
|
|
|
|
|
struct Fail<T>(T);
|
|
|
|
impl<T> Fail<T> {
|
2024-03-15 15:06:40 -05:00
|
|
|
const C: () = panic!(); //~ERROR evaluation of `Fail::<i32>::C` failed
|
2024-03-13 09:07:47 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// This function is not actually called, but it is mentioned in dead code in a function that is
|
|
|
|
// called. Make sure we still find this error.
|
|
|
|
// This relies on mono-item collection checking `required_consts` in functions that syntactically
|
|
|
|
// are called in collected functions (even inside dead code).
|
|
|
|
#[inline(never)]
|
|
|
|
fn not_called<T>() {
|
|
|
|
if false {
|
|
|
|
let _ = Fail::<T>::C;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[inline(never)]
|
|
|
|
fn called<T>() {
|
|
|
|
if false {
|
|
|
|
not_called::<T>();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn main() {
|
|
|
|
called::<i32>();
|
|
|
|
}
|