2012-03-22 19:19:01 -05:00
|
|
|
// Don't leak the unique pointers
|
|
|
|
|
|
|
|
type u = {
|
|
|
|
a: int,
|
|
|
|
b: int,
|
|
|
|
c: *int
|
|
|
|
};
|
|
|
|
|
2012-08-15 20:46:55 -05:00
|
|
|
struct r {
|
2012-09-06 21:40:15 -05:00
|
|
|
v: u,
|
2012-06-24 17:09:57 -05:00
|
|
|
drop unsafe {
|
2012-09-18 19:34:08 -05:00
|
|
|
let v2: ~int = cast::reinterpret_cast(&self.v.c);
|
2012-06-24 17:09:57 -05:00
|
|
|
}
|
2012-03-22 19:19:01 -05:00
|
|
|
}
|
|
|
|
|
2012-09-05 17:58:43 -05:00
|
|
|
fn r(v: u) -> r {
|
|
|
|
r {
|
|
|
|
v: v
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-03-22 19:19:01 -05:00
|
|
|
enum t = {
|
2012-08-20 14:23:37 -05:00
|
|
|
mut next: Option<@t>,
|
2012-03-22 19:19:01 -05:00
|
|
|
r: r
|
|
|
|
};
|
|
|
|
|
|
|
|
fn main() unsafe {
|
|
|
|
let i1 = ~0xA;
|
2012-09-18 19:34:08 -05:00
|
|
|
let i1p = cast::reinterpret_cast(&i1);
|
|
|
|
cast::forget(i1);
|
2012-03-22 19:19:01 -05:00
|
|
|
let i2 = ~0xA;
|
2012-09-18 19:34:08 -05:00
|
|
|
let i2p = cast::reinterpret_cast(&i2);
|
|
|
|
cast::forget(i2);
|
2012-03-22 19:19:01 -05:00
|
|
|
|
|
|
|
let u1 = {a: 0xB, b: 0xC, c: i1p};
|
|
|
|
let u2 = {a: 0xB, b: 0xC, c: i2p};
|
|
|
|
|
|
|
|
let x1 = @t({
|
2012-08-20 14:23:37 -05:00
|
|
|
mut next: None,
|
2012-03-22 19:19:01 -05:00
|
|
|
r: r(u1)
|
|
|
|
});
|
|
|
|
let x2 = @t({
|
2012-08-20 14:23:37 -05:00
|
|
|
mut next: None,
|
2012-03-22 19:19:01 -05:00
|
|
|
r: r(u2)
|
|
|
|
});
|
2012-08-20 14:23:37 -05:00
|
|
|
x1.next = Some(x2);
|
|
|
|
x2.next = Some(x1);
|
2012-03-22 19:19:01 -05:00
|
|
|
}
|