f94d671bfa
This commit revisits the `cast` module in libcore and libstd, and scrutinizes all functions inside of it. The result was to remove the `cast` module entirely, folding all functionality into the `mem` module. Specifically, this is the fate of each function in the `cast` module. * transmute - This function was moved to `mem`, but it is now marked as #[unstable]. This is due to planned changes to the `transmute` function and how it can be invoked (see the #[unstable] comment). For more information, see RFC 5 and #12898 * transmute_copy - This function was moved to `mem`, with clarification that is is not an error to invoke it with T/U that are different sizes, but rather that it is strongly discouraged. This function is now #[stable] * forget - This function was moved to `mem` and marked #[stable] * bump_box_refcount - This function was removed due to the deprecation of managed boxes as well as its questionable utility. * transmute_mut - This function was previously deprecated, and removed as part of this commit. * transmute_mut_unsafe - This function doesn't serve much of a purpose when it can be achieved with an `as` in safe code, so it was removed. * transmute_lifetime - This function was removed because it is likely a strong indication that code is incorrect in the first place. * transmute_mut_lifetime - This function was removed for the same reasons as `transmute_lifetime` * copy_lifetime - This function was moved to `mem`, but it is marked `#[unstable]` now due to the likelihood of being removed in the future if it is found to not be very useful. * copy_mut_lifetime - This function was also moved to `mem`, but had the same treatment as `copy_lifetime`. * copy_lifetime_vec - This function was removed because it is not used today, and its existence is not necessary with DST (copy_lifetime will suffice). In summary, the cast module was stripped down to these functions, and then the functions were moved to the `mem` module. transmute - #[unstable] transmute_copy - #[stable] forget - #[stable] copy_lifetime - #[unstable] copy_mut_lifetime - #[unstable] [breaking-change]
75 lines
2.1 KiB
Rust
75 lines
2.1 KiB
Rust
// Copyright 2013 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.
|
|
|
|
//! Implementation of running at_exit routines
|
|
//!
|
|
//! Documentation can be found on the `rt::at_exit` function.
|
|
|
|
use iter::Iterator;
|
|
use kinds::Send;
|
|
use mem;
|
|
use option::{Some, None};
|
|
use owned::Box;
|
|
use ptr::RawPtr;
|
|
use slice::OwnedVector;
|
|
use unstable::sync::Exclusive;
|
|
use vec::Vec;
|
|
|
|
type Queue = Exclusive<Vec<proc():Send>>;
|
|
|
|
// You'll note that these variables are *not* atomic, and this is done on
|
|
// purpose. This module is designed to have init() called *once* in a
|
|
// single-task context, and then run() is called only once in another
|
|
// single-task context. As a result of this, only the `push` function is
|
|
// thread-safe, and it assumes that the `init` function has run previously.
|
|
static mut QUEUE: *mut Queue = 0 as *mut Queue;
|
|
static mut RUNNING: bool = false;
|
|
|
|
pub fn init() {
|
|
unsafe {
|
|
rtassert!(!RUNNING);
|
|
rtassert!(QUEUE.is_null());
|
|
let state: Box<Queue> = box Exclusive::new(vec!());
|
|
QUEUE = mem::transmute(state);
|
|
}
|
|
}
|
|
|
|
pub fn push(f: proc():Send) {
|
|
unsafe {
|
|
rtassert!(!RUNNING);
|
|
rtassert!(!QUEUE.is_null());
|
|
let state: &mut Queue = mem::transmute(QUEUE);
|
|
let mut f = Some(f);
|
|
state.with(|arr| {
|
|
arr.push(f.take_unwrap());
|
|
});
|
|
}
|
|
}
|
|
|
|
pub fn run() {
|
|
let vec = unsafe {
|
|
rtassert!(!RUNNING);
|
|
rtassert!(!QUEUE.is_null());
|
|
RUNNING = true;
|
|
let state: Box<Queue> = mem::transmute(QUEUE);
|
|
QUEUE = 0 as *mut Queue;
|
|
let mut vec = None;
|
|
state.with(|arr| {
|
|
vec = Some(mem::replace(arr, vec!()));
|
|
});
|
|
vec.take_unwrap()
|
|
};
|
|
|
|
|
|
for f in vec.move_iter() {
|
|
f();
|
|
}
|
|
}
|