2012-06-24 15:11:25 -07:00
|
|
|
// same as resource-cycle2, but be sure to give r multiple fields...
|
|
|
|
|
|
|
|
// Don't leak the unique pointers
|
|
|
|
|
|
|
|
type u = {
|
|
|
|
a: int,
|
|
|
|
b: int,
|
|
|
|
c: *int
|
|
|
|
};
|
|
|
|
|
2012-08-15 18:46:55 -07:00
|
|
|
struct r {
|
2012-09-06 19:40:15 -07:00
|
|
|
v: u,
|
|
|
|
w: int,
|
|
|
|
x: *int,
|
2012-06-24 15:11:25 -07:00
|
|
|
drop unsafe {
|
2012-09-18 17:34:08 -07:00
|
|
|
let _v2: ~int = cast::reinterpret_cast(&self.v.c);
|
2012-06-24 15:11:25 -07:00
|
|
|
// let _v3: ~int = unsafe::reinterpret_cast(self.x);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-09-05 15:58:43 -07:00
|
|
|
fn r(v: u, w: int, _x: *int) -> r unsafe {
|
|
|
|
r {
|
|
|
|
v: v,
|
|
|
|
w: w,
|
2012-09-18 17:34:08 -07:00
|
|
|
x: cast::reinterpret_cast(&0)
|
2012-09-05 15:58:43 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-06-24 15:11:25 -07:00
|
|
|
enum t = {
|
2012-08-20 12:23:37 -07:00
|
|
|
mut next: Option<@t>,
|
2012-06-24 15:11:25 -07:00
|
|
|
r: r
|
|
|
|
};
|
|
|
|
|
|
|
|
fn main() unsafe {
|
|
|
|
let i1 = ~0xA;
|
2012-09-18 17:34:08 -07:00
|
|
|
let i1p = cast::reinterpret_cast(&i1);
|
|
|
|
cast::forget(i1);
|
2012-06-24 15:11:25 -07:00
|
|
|
let i2 = ~0xA;
|
2012-09-18 17:34:08 -07:00
|
|
|
let i2p = cast::reinterpret_cast(&i2);
|
|
|
|
cast::forget(i2);
|
2012-06-24 15:11:25 -07:00
|
|
|
|
|
|
|
let u1 = {a: 0xB, b: 0xC, c: i1p};
|
|
|
|
let u2 = {a: 0xB, b: 0xC, c: i2p};
|
|
|
|
|
|
|
|
let x1 = @t({
|
2012-08-20 12:23:37 -07:00
|
|
|
mut next: None,
|
2012-06-24 15:11:25 -07:00
|
|
|
r: r(u1, 42, i1p)
|
|
|
|
});
|
|
|
|
let x2 = @t({
|
2012-08-20 12:23:37 -07:00
|
|
|
mut next: None,
|
2012-06-24 15:11:25 -07:00
|
|
|
r: r(u2, 42, i2p)
|
|
|
|
});
|
2012-08-20 12:23:37 -07:00
|
|
|
x1.next = Some(x2);
|
|
|
|
x2.next = Some(x1);
|
2012-06-24 15:11:25 -07:00
|
|
|
}
|