2020-11-09 00:00:00 +00:00
|
|
|
// Tests inlining of diverging calls.
|
|
|
|
//
|
2023-06-08 09:18:34 +02:00
|
|
|
// EMIT_MIR_FOR_EACH_PANIC_STRATEGY
|
2023-06-04 20:21:00 -04:00
|
|
|
// compile-flags: -Zinline-mir-hint-threshold=1000
|
2020-11-09 00:00:00 +00:00
|
|
|
#![crate_type = "lib"]
|
|
|
|
|
|
|
|
// EMIT_MIR inline_diverging.f.Inline.diff
|
|
|
|
pub fn f() {
|
2023-10-20 18:03:13 -07:00
|
|
|
// CHECK-LABEL: fn f(
|
|
|
|
// CHECK: (inlined sleep)
|
2020-11-09 00:00:00 +00:00
|
|
|
sleep();
|
|
|
|
}
|
|
|
|
|
|
|
|
// EMIT_MIR inline_diverging.g.Inline.diff
|
|
|
|
pub fn g(i: i32) -> u32 {
|
|
|
|
if i > 0 {
|
|
|
|
i as u32
|
|
|
|
} else {
|
2023-10-20 18:03:13 -07:00
|
|
|
// CHECK-LABEL: fn g(
|
|
|
|
// CHECK: (inlined panic)
|
2020-11-09 00:00:00 +00:00
|
|
|
panic();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// EMIT_MIR inline_diverging.h.Inline.diff
|
|
|
|
pub fn h() {
|
2023-10-20 18:03:13 -07:00
|
|
|
// CHECK-LABEL: fn h(
|
|
|
|
// CHECK: (inlined call_twice::<!, fn() -> ! {sleep}>)
|
|
|
|
// CHECK-NOT: inlined
|
2020-11-09 00:00:00 +00:00
|
|
|
call_twice(sleep);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[inline(always)]
|
|
|
|
pub fn call_twice<R, F: Fn() -> R>(f: F) -> (R, R) {
|
|
|
|
let a = f();
|
|
|
|
let b = f();
|
|
|
|
(a, b)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[inline(always)]
|
|
|
|
fn panic() -> ! {
|
|
|
|
panic!();
|
|
|
|
}
|
|
|
|
|
|
|
|
#[inline(always)]
|
|
|
|
fn sleep() -> ! {
|
|
|
|
loop {}
|
|
|
|
}
|