FenrirWolf
7 years ago
committed by
GitHub
52 changed files with 2349 additions and 2119 deletions
@ -0,0 +1,121 @@
@@ -0,0 +1,121 @@
|
||||
// Copyright 2017 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.
|
||||
|
||||
//! dox
|
||||
|
||||
#![unstable(issue = "32838", feature = "allocator_api")] |
||||
|
||||
#[doc(inline)] #[allow(deprecated)] pub use alloc_crate::alloc::Heap; |
||||
#[doc(inline)] pub use alloc_crate::alloc::Global; |
||||
#[doc(inline)] pub use alloc_system::System; |
||||
#[doc(inline)] pub use core::alloc::*; |
||||
|
||||
#[cfg(not(test))] |
||||
#[doc(hidden)] |
||||
#[allow(unused_attributes)] |
||||
pub mod __default_lib_allocator { |
||||
use super::{System, Layout, GlobalAlloc, Opaque}; |
||||
// for symbol names src/librustc/middle/allocator.rs
|
||||
// for signatures src/librustc_allocator/lib.rs
|
||||
|
||||
// linkage directives are provided as part of the current compiler allocator
|
||||
// ABI
|
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_alloc(size: usize, align: usize) -> *mut u8 { |
||||
let layout = Layout::from_size_align_unchecked(size, align); |
||||
System.alloc(layout) as *mut u8 |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_oom() -> ! { |
||||
System.oom() |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_dealloc(ptr: *mut u8, |
||||
size: usize, |
||||
align: usize) { |
||||
System.dealloc(ptr as *mut Opaque, Layout::from_size_align_unchecked(size, align)) |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_realloc(ptr: *mut u8, |
||||
old_size: usize, |
||||
align: usize, |
||||
new_size: usize) -> *mut u8 { |
||||
let old_layout = Layout::from_size_align_unchecked(old_size, align); |
||||
System.realloc(ptr as *mut Opaque, old_layout, new_size) as *mut u8 |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_alloc_zeroed(size: usize, align: usize) -> *mut u8 { |
||||
let layout = Layout::from_size_align_unchecked(size, align); |
||||
System.alloc_zeroed(layout) as *mut u8 |
||||
} |
||||
|
||||
#[cfg(stage0)] |
||||
pub mod stage0 { |
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_usable_size(_layout: *const u8, |
||||
_min: *mut usize, |
||||
_max: *mut usize) { |
||||
unimplemented!() |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_alloc_excess(_size: usize, |
||||
_align: usize, |
||||
_excess: *mut usize, |
||||
_err: *mut u8) -> *mut u8 { |
||||
unimplemented!() |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_realloc_excess(_ptr: *mut u8, |
||||
_old_size: usize, |
||||
_old_align: usize, |
||||
_new_size: usize, |
||||
_new_align: usize, |
||||
_excess: *mut usize, |
||||
_err: *mut u8) -> *mut u8 { |
||||
unimplemented!() |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_grow_in_place(_ptr: *mut u8, |
||||
_old_size: usize, |
||||
_old_align: usize, |
||||
_new_size: usize, |
||||
_new_align: usize) -> u8 { |
||||
unimplemented!() |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_shrink_in_place(_ptr: *mut u8, |
||||
_old_size: usize, |
||||
_old_align: usize, |
||||
_new_size: usize, |
||||
_new_align: usize) -> u8 { |
||||
unimplemented!() |
||||
} |
||||
|
||||
} |
||||
} |
@ -1,175 +0,0 @@
@@ -1,175 +0,0 @@
|
||||
// Copyright 2017 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.
|
||||
|
||||
//! dox
|
||||
|
||||
#![unstable(issue = "32838", feature = "allocator_api")] |
||||
|
||||
pub use alloc::heap::{Heap, Alloc, Layout, Excess, CannotReallocInPlace, AllocErr}; |
||||
pub use alloc_system::System; |
||||
|
||||
#[cfg(not(test))] |
||||
#[doc(hidden)] |
||||
#[allow(unused_attributes)] |
||||
pub mod __default_lib_allocator { |
||||
use super::{System, Layout, Alloc, AllocErr}; |
||||
use ptr; |
||||
|
||||
// for symbol names src/librustc/middle/allocator.rs
|
||||
// for signatures src/librustc_allocator/lib.rs
|
||||
|
||||
// linkage directives are provided as part of the current compiler allocator
|
||||
// ABI
|
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_alloc(size: usize, |
||||
align: usize, |
||||
err: *mut u8) -> *mut u8 { |
||||
let layout = Layout::from_size_align_unchecked(size, align); |
||||
match System.alloc(layout) { |
||||
Ok(p) => p, |
||||
Err(e) => { |
||||
ptr::write(err as *mut AllocErr, e); |
||||
0 as *mut u8 |
||||
} |
||||
} |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_oom(err: *const u8) -> ! { |
||||
System.oom((*(err as *const AllocErr)).clone()) |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_dealloc(ptr: *mut u8, |
||||
size: usize, |
||||
align: usize) { |
||||
System.dealloc(ptr, Layout::from_size_align_unchecked(size, align)) |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_usable_size(layout: *const u8, |
||||
min: *mut usize, |
||||
max: *mut usize) { |
||||
let pair = System.usable_size(&*(layout as *const Layout)); |
||||
*min = pair.0; |
||||
*max = pair.1; |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_realloc(ptr: *mut u8, |
||||
old_size: usize, |
||||
old_align: usize, |
||||
new_size: usize, |
||||
new_align: usize, |
||||
err: *mut u8) -> *mut u8 { |
||||
let old_layout = Layout::from_size_align_unchecked(old_size, old_align); |
||||
let new_layout = Layout::from_size_align_unchecked(new_size, new_align); |
||||
match System.realloc(ptr, old_layout, new_layout) { |
||||
Ok(p) => p, |
||||
Err(e) => { |
||||
ptr::write(err as *mut AllocErr, e); |
||||
0 as *mut u8 |
||||
} |
||||
} |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_alloc_zeroed(size: usize, |
||||
align: usize, |
||||
err: *mut u8) -> *mut u8 { |
||||
let layout = Layout::from_size_align_unchecked(size, align); |
||||
match System.alloc_zeroed(layout) { |
||||
Ok(p) => p, |
||||
Err(e) => { |
||||
ptr::write(err as *mut AllocErr, e); |
||||
0 as *mut u8 |
||||
} |
||||
} |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_alloc_excess(size: usize, |
||||
align: usize, |
||||
excess: *mut usize, |
||||
err: *mut u8) -> *mut u8 { |
||||
let layout = Layout::from_size_align_unchecked(size, align); |
||||
match System.alloc_excess(layout) { |
||||
Ok(p) => { |
||||
*excess = p.1; |
||||
p.0 |
||||
} |
||||
Err(e) => { |
||||
ptr::write(err as *mut AllocErr, e); |
||||
0 as *mut u8 |
||||
} |
||||
} |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_realloc_excess(ptr: *mut u8, |
||||
old_size: usize, |
||||
old_align: usize, |
||||
new_size: usize, |
||||
new_align: usize, |
||||
excess: *mut usize, |
||||
err: *mut u8) -> *mut u8 { |
||||
let old_layout = Layout::from_size_align_unchecked(old_size, old_align); |
||||
let new_layout = Layout::from_size_align_unchecked(new_size, new_align); |
||||
match System.realloc_excess(ptr, old_layout, new_layout) { |
||||
Ok(p) => { |
||||
*excess = p.1; |
||||
p.0 |
||||
} |
||||
Err(e) => { |
||||
ptr::write(err as *mut AllocErr, e); |
||||
0 as *mut u8 |
||||
} |
||||
} |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_grow_in_place(ptr: *mut u8, |
||||
old_size: usize, |
||||
old_align: usize, |
||||
new_size: usize, |
||||
new_align: usize) -> u8 { |
||||
let old_layout = Layout::from_size_align_unchecked(old_size, old_align); |
||||
let new_layout = Layout::from_size_align_unchecked(new_size, new_align); |
||||
match System.grow_in_place(ptr, old_layout, new_layout) { |
||||
Ok(()) => 1, |
||||
Err(_) => 0, |
||||
} |
||||
} |
||||
|
||||
#[no_mangle] |
||||
#[rustc_std_internal_symbol] |
||||
pub unsafe extern fn __rdl_shrink_in_place(ptr: *mut u8, |
||||
old_size: usize, |
||||
old_align: usize, |
||||
new_size: usize, |
||||
new_align: usize) -> u8 { |
||||
let old_layout = Layout::from_size_align_unchecked(old_size, old_align); |
||||
let new_layout = Layout::from_size_align_unchecked(new_size, new_align); |
||||
match System.shrink_in_place(ptr, old_layout, new_layout) { |
||||
Ok(()) => 1, |
||||
Err(_) => 0, |
||||
} |
||||
} |
||||
} |
@ -1,80 +0,0 @@
@@ -1,80 +0,0 @@
|
||||
// Copyright 2017 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.
|
||||
|
||||
use error::Error; |
||||
// TODO: Add these consts to the libc crate for newlib
|
||||
mod exit { |
||||
pub const SUCCESS: i32 = 0; |
||||
pub const FAILURE: i32 = 1; |
||||
} |
||||
|
||||
/// A trait for implementing arbitrary return types in the `main` function.
|
||||
///
|
||||
/// The c-main function only supports to return integers as return type.
|
||||
/// So, every type implementing the `Termination` trait has to be converted
|
||||
/// to an integer.
|
||||
///
|
||||
/// The default implementations are returning `libc::EXIT_SUCCESS` to indicate
|
||||
/// a successful execution. In case of a failure, `libc::EXIT_FAILURE` is returned.
|
||||
#[cfg_attr(not(test), lang = "termination")] |
||||
#[unstable(feature = "termination_trait", issue = "43301")] |
||||
#[rustc_on_unimplemented =
|
||||
"`main` can only return types that implement {Termination}, not `{Self}`"] |
||||
pub trait Termination { |
||||
/// Is called to get the representation of the value as status code.
|
||||
/// This status code is returned to the operating system.
|
||||
fn report(self) -> i32; |
||||
} |
||||
|
||||
#[unstable(feature = "termination_trait", issue = "43301")] |
||||
impl Termination for () { |
||||
fn report(self) -> i32 { exit::SUCCESS } |
||||
} |
||||
|
||||
#[unstable(feature = "termination_trait", issue = "43301")] |
||||
impl<T: Termination, E: Error> Termination for Result<T, E> { |
||||
fn report(self) -> i32 { |
||||
match self { |
||||
Ok(val) => val.report(), |
||||
Err(err) => { |
||||
print_error(err); |
||||
exit::FAILURE |
||||
} |
||||
} |
||||
} |
||||
} |
||||
|
||||
#[unstable(feature = "termination_trait", issue = "43301")] |
||||
fn print_error<E: Error>(err: E) { |
||||
eprintln!("Error: {}", err.description()); |
||||
|
||||
if let Some(ref err) = err.cause() { |
||||
eprintln!("Caused by: {}", err.description()); |
||||
} |
||||
} |
||||
|
||||
#[unstable(feature = "termination_trait", issue = "43301")] |
||||
impl Termination for ! { |
||||
fn report(self) -> i32 { unreachable!(); } |
||||
} |
||||
|
||||
#[unstable(feature = "termination_trait", issue = "43301")] |
||||
impl Termination for bool { |
||||
fn report(self) -> i32 { |
||||
if self { exit::SUCCESS } else { exit::FAILURE } |
||||
} |
||||
} |
||||
|
||||
#[unstable(feature = "termination_trait", issue = "43301")] |
||||
impl Termination for i32 { |
||||
fn report(self) -> i32 { |
||||
self |
||||
} |
||||
} |
Loading…
Reference in new issue