rust/tests/ui/issues/issue-16492.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

68 lines
1.3 KiB
Rust
Raw Normal View History

// run-pass
#![allow(non_snake_case)]
use std::rc::Rc;
use std::cell::Cell;
struct Field {
number: usize,
state: Rc<Cell<usize>>
}
impl Field {
fn new(number: usize, state: Rc<Cell<usize>>) -> Field {
Field {
number: number,
state: state
}
}
}
impl Drop for Field {
fn drop(&mut self) {
println!("Dropping field {}", self.number);
assert_eq!(self.state.get(), self.number);
self.state.set(self.state.get()+1);
}
}
struct NoDropImpl {
_one: Field,
_two: Field,
_three: Field
}
struct HasDropImpl {
_one: Field,
_two: Field,
_three: Field
}
impl Drop for HasDropImpl {
fn drop(&mut self) {
println!("HasDropImpl.drop()");
assert_eq!(self._one.state.get(), 0);
self._one.state.set(1);
}
}
pub fn main() {
let state = Rc::new(Cell::new(1));
let noImpl = NoDropImpl {
_one: Field::new(1, state.clone()),
_two: Field::new(2, state.clone()),
_three: Field::new(3, state.clone())
};
drop(noImpl);
assert_eq!(state.get(), 4);
state.set(0);
let hasImpl = HasDropImpl {
_one: Field::new(1, state.clone()),
_two: Field::new(2, state.clone()),
_three: Field::new(3, state.clone())
};
drop(hasImpl);
assert_eq!(state.get(), 4);
}