rust/src/test/run-pass/issue-2735-3.rs
Patrick Walton dcbf4ec2a1 librustc: Put #[unsafe_destructor] behind a feature gate.
Closes #8142.

This is not the semantics we want long-term. You can continue to use
`#[unsafe_destructor]`, but you'll need to add
`#![feature(unsafe_destructor)]` to the crate attributes.

[breaking-change]
2014-06-20 14:24:31 -07:00

39 lines
942 B
Rust

// Copyright 2012 The Rust Project Developers. See the COPYRIGHT
// file at the top-level directory of this distribution and at
// http://rust-lang.org/COPYRIGHT.
//
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
// option. This file may not be copied, modified, or distributed
// except according to those terms.
#![feature(managed_boxes, unsafe_destructor)]
use std::cell::Cell;
use std::gc::{Gc, GC};
// This test should behave exactly like issue-2735-2
struct defer {
b: Gc<Cell<bool>>,
}
#[unsafe_destructor]
impl Drop for defer {
fn drop(&mut self) {
self.b.set(true);
}
}
fn defer(b: Gc<Cell<bool>>) -> defer {
defer {
b: b
}
}
pub fn main() {
let dtor_ran = box(GC) Cell::new(false);
defer(dtor_ran);
assert!(dtor_ran.get());
}