2023-10-16 12:36:39 -05:00
|
|
|
// skip-filecheck
|
2023-06-08 02:18:34 -05:00
|
|
|
// EMIT_MIR_FOR_EACH_PANIC_STRATEGY
|
2020-10-16 19:25:31 -05:00
|
|
|
// Check that DestinationPropagation does not propagate an assignment to a function argument
|
2017-11-05 07:08:30 -06:00
|
|
|
// (doing so can break usages of the original argument value)
|
2022-04-24 16:34:24 -05:00
|
|
|
// unit-test: DestinationPropagation
|
2017-11-05 07:08:30 -06:00
|
|
|
fn dummy(x: u8) -> u8 {
|
|
|
|
x
|
|
|
|
}
|
|
|
|
|
2020-10-16 19:25:31 -05:00
|
|
|
// EMIT_MIR copy_propagation_arg.foo.DestinationPropagation.diff
|
2017-11-05 07:08:30 -06:00
|
|
|
fn foo(mut x: u8) {
|
2021-08-22 11:15:49 -05:00
|
|
|
// calling `dummy` to make a use of `x` that copyprop cannot eliminate
|
2017-11-05 07:08:30 -06:00
|
|
|
x = dummy(x); // this will assign a local to `x`
|
|
|
|
}
|
|
|
|
|
2020-10-16 19:25:31 -05:00
|
|
|
// EMIT_MIR copy_propagation_arg.bar.DestinationPropagation.diff
|
2017-11-05 07:08:30 -06:00
|
|
|
fn bar(mut x: u8) {
|
|
|
|
dummy(x);
|
|
|
|
x = 5;
|
|
|
|
}
|
|
|
|
|
2020-10-16 19:25:31 -05:00
|
|
|
// EMIT_MIR copy_propagation_arg.baz.DestinationPropagation.diff
|
2022-04-24 16:34:24 -05:00
|
|
|
fn baz(mut x: i32) -> i32 {
|
2017-11-05 07:08:30 -06:00
|
|
|
// self-assignment to a function argument should be eliminated
|
|
|
|
x = x;
|
2022-04-24 16:34:24 -05:00
|
|
|
x
|
2017-11-05 07:08:30 -06:00
|
|
|
}
|
|
|
|
|
2020-10-16 19:25:31 -05:00
|
|
|
// EMIT_MIR copy_propagation_arg.arg_src.DestinationPropagation.diff
|
2017-12-03 02:38:56 -06:00
|
|
|
fn arg_src(mut x: i32) -> i32 {
|
|
|
|
let y = x;
|
|
|
|
x = 123; // Don't propagate this assignment to `y`
|
|
|
|
y
|
|
|
|
}
|
|
|
|
|
2017-11-05 07:08:30 -06:00
|
|
|
fn main() {
|
|
|
|
// Make sure the function actually gets instantiated.
|
|
|
|
foo(0);
|
|
|
|
bar(0);
|
2017-11-05 21:35:43 -06:00
|
|
|
baz(0);
|
2017-12-03 02:38:56 -06:00
|
|
|
arg_src(0);
|
2017-11-05 07:08:30 -06:00
|
|
|
}
|