// run-pass #![allow(non_camel_case_types)] #![allow(dead_code)] use std::cell::Cell; // Resources can't be copied, but storing into data structures counts // as a move unless the stored thing is used afterwards. struct r<'a> { i: &'a Cell, } struct BoxR<'a> { x: r<'a> } impl<'a> Drop for r<'a> { fn drop(&mut self) { self.i.set(self.i.get() + 1) } } fn r(i: &Cell) -> r { r { i: i } } fn test_rec() { let i = &Cell::new(0); { let _a = BoxR {x: r(i)}; } assert_eq!(i.get(), 1); } fn test_tag() { enum t<'a> { t0(r<'a>), } let i = &Cell::new(0); { let _a = t::t0(r(i)); } assert_eq!(i.get(), 1); } fn test_tup() { let i = &Cell::new(0); { let _a = (r(i), 0); } assert_eq!(i.get(), 1); } fn test_unique() { let i = &Cell::new(0); { let _a: Box<_> = Box::new(r(i)); } assert_eq!(i.get(), 1); } fn test_unique_rec() { let i = &Cell::new(0); { let _a: Box<_> = Box::new(BoxR { x: r(i) }); } assert_eq!(i.get(), 1); } pub fn main() { test_rec(); test_tag(); test_tup(); test_unique(); test_unique_rec(); }