4fc0452ace
The `print!` and `println!` macros are now the preferred method of printing, and so there is no reason to export the `stdio` functions in the prelude. The functions have also been replaced by their macro counterparts in the tutorial and other documentation so that newcomers don't get confused about what they should be using.
48 lines
1.0 KiB
Rust
48 lines
1.0 KiB
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)];
|
|
|
|
// A test case for #2548.
|
|
|
|
use std::cell::Cell;
|
|
|
|
struct foo {
|
|
x: @Cell<int>,
|
|
}
|
|
|
|
#[unsafe_destructor]
|
|
impl Drop for foo {
|
|
fn drop(&mut self) {
|
|
unsafe {
|
|
println!("Goodbye, World!");
|
|
self.x.set(self.x.get() + 1);
|
|
}
|
|
}
|
|
}
|
|
|
|
fn foo(x: @Cell<int>) -> foo {
|
|
foo { x: x }
|
|
}
|
|
|
|
fn main() {
|
|
let x = @Cell::new(0);
|
|
|
|
{
|
|
let mut res = foo(x);
|
|
|
|
let mut v = ~[];
|
|
v = ~[(res)] + v; //~ failed to find an implementation of trait
|
|
assert_eq!(v.len(), 2);
|
|
}
|
|
|
|
assert_eq!(x.get(), 1);
|
|
}
|