2022-08-02 17:44:25 -07:00
|
|
|
// unit-test: AddRetag
|
2019-10-18 14:47:54 -07:00
|
|
|
// ignore-wasm32-bare compiled with panic=abort by default
|
2018-10-24 13:38:09 +02:00
|
|
|
// ignore-tidy-linelength
|
|
|
|
// compile-flags: -Z mir-emit-retag -Z mir-opt-level=0 -Z span_free_formats
|
|
|
|
|
|
|
|
#![allow(unused)]
|
|
|
|
|
|
|
|
struct Test(i32);
|
|
|
|
|
2020-08-31 18:11:44 +01:00
|
|
|
// EMIT_MIR retag.{impl#0}-foo.SimplifyCfg-elaborate-drops.after.mir
|
|
|
|
// EMIT_MIR retag.{impl#0}-foo_shr.SimplifyCfg-elaborate-drops.after.mir
|
2018-10-24 13:38:09 +02:00
|
|
|
impl Test {
|
|
|
|
// Make sure we run the pass on a method, not just on bare functions.
|
2020-03-19 11:40:38 +00:00
|
|
|
fn foo<'x>(&self, x: &'x mut i32) -> &'x mut i32 {
|
|
|
|
x
|
|
|
|
}
|
|
|
|
fn foo_shr<'x>(&self, x: &'x i32) -> &'x i32 {
|
|
|
|
x
|
|
|
|
}
|
2018-10-24 13:38:09 +02:00
|
|
|
}
|
|
|
|
|
2020-07-27 21:22:43 +02:00
|
|
|
// EMIT_MIR core.ptr-drop_in_place.Test.SimplifyCfg-make_shim.after.mir
|
2020-04-02 21:09:01 +00:00
|
|
|
|
2019-08-05 22:27:00 +02:00
|
|
|
impl Drop for Test {
|
|
|
|
fn drop(&mut self) {}
|
|
|
|
}
|
|
|
|
|
2020-07-27 21:22:43 +02:00
|
|
|
// EMIT_MIR retag.main.SimplifyCfg-elaborate-drops.after.mir
|
2020-08-31 18:11:44 +01:00
|
|
|
// EMIT_MIR retag.main-{closure#0}.SimplifyCfg-elaborate-drops.after.mir
|
2018-10-24 13:38:09 +02:00
|
|
|
fn main() {
|
|
|
|
let mut x = 0;
|
|
|
|
{
|
|
|
|
let v = Test(0).foo(&mut x); // just making sure we do not panic when there is a tuple struct ctor
|
|
|
|
let w = { v }; // assignment
|
2018-11-06 11:04:10 +01:00
|
|
|
let w = w; // reborrow
|
|
|
|
// escape-to-raw (mut)
|
|
|
|
let _w = w as *mut _;
|
2018-10-24 13:38:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Also test closures
|
2020-03-19 11:40:38 +00:00
|
|
|
let c: fn(&i32) -> &i32 = |x: &i32| -> &i32 {
|
|
|
|
let _y = x;
|
|
|
|
x
|
|
|
|
};
|
2018-10-24 13:38:09 +02:00
|
|
|
let _w = c(&x);
|
|
|
|
|
|
|
|
// need to call `foo_shr` or it doesn't even get generated
|
|
|
|
Test(0).foo_shr(&0);
|
2018-11-06 11:04:10 +01:00
|
|
|
|
|
|
|
// escape-to-raw (shr)
|
|
|
|
let _w = _w as *const _;
|
2021-05-07 09:36:45 +02:00
|
|
|
|
|
|
|
array_casts();
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Casting directly to an array should also go through `&raw` and thus add appropriate retags.
|
|
|
|
// EMIT_MIR retag.array_casts.SimplifyCfg-elaborate-drops.after.mir
|
|
|
|
fn array_casts() {
|
|
|
|
let mut x: [usize; 2] = [0, 0];
|
|
|
|
let p = &mut x as *mut usize;
|
|
|
|
unsafe { *p.add(1) = 1; }
|
|
|
|
|
|
|
|
let x: [usize; 2] = [0, 1];
|
|
|
|
let p = &x as *const usize;
|
|
|
|
assert_eq!(unsafe { *p.add(1) }, 1);
|
2018-10-24 13:38:09 +02:00
|
|
|
}
|