Skip to content

Commit dba9337

Browse files
committed
auto merge of #6366 : catamorphism/rust/issue-3920, r=catamorphism
r? @nikomatsakis as per #3920
2 parents fdf601e + ca18ed8 commit dba9337

File tree

2 files changed

+24
-2
lines changed

2 files changed

+24
-2
lines changed

src/libcore/unstable/intrinsics.rs

+7-2
Original file line numberDiff line numberDiff line change
@@ -42,12 +42,17 @@ pub extern "rust-intrinsic" {
4242

4343
pub fn get_tydesc<T>() -> *();
4444

45-
pub fn init<T>() -> T;
45+
/// init is unsafe because it returns a zeroed-out datum,
46+
/// which is unsafe unless T is POD. We don't have a POD
47+
/// kind yet. (See #4074)
48+
pub unsafe fn init<T>() -> T;
4649

4750
#[cfg(not(stage0))]
4851
pub unsafe fn uninit<T>() -> T;
4952

50-
pub fn forget<T>(_: T) -> ();
53+
/// forget is unsafe because the caller is responsible for
54+
/// ensuring the argument is deallocated already
55+
pub unsafe fn forget<T>(_: T) -> ();
5156

5257
pub fn needs_drop<T>() -> bool;
5358

Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
// Copyright 2013 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
use core::unstable::intrinsics::{init, forget};
12+
13+
// Test that the `forget` and `init` intrinsics are really unsafe
14+
pub fn main() {
15+
let stuff = init::<int>(); //~ ERROR access to unsafe function requires unsafe
16+
forget(stuff); //~ ERROR access to unsafe function requires unsafe
17+
}

0 commit comments

Comments
 (0)