// 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 or the MIT license // , at your // option. This file may not be copied, modified, or distributed // except according to those terms. // Test which of the builtin types are considered sendable. fn assert_send() { } trait Dummy { } fn test<'a,T,U:Send>(_: &'a int) { // lifetime pointers with 'static lifetime are ok assert_send::<&'static int>(); assert_send::<&'static str>(); assert_send::<&'static [int]>(); // whether or not they are mutable assert_send::<&'static mut int>(); // otherwise lifetime pointers are not ok assert_send::<&'a int>(); //~ ERROR does not fulfill `Send` assert_send::<&'a str>(); //~ ERROR does not fulfill `Send` assert_send::<&'a [int]>(); //~ ERROR does not fulfill `Send` // boxes are ok assert_send::>(); assert_send::(); assert_send:: >(); // but not if they own a bad thing assert_send::>(); //~ ERROR does not fulfill `Send` // careful with object types, who knows what they close over... assert_send::<&'static Dummy>(); //~ ERROR does not fulfill `Send` assert_send::<&'a Dummy>(); //~ ERROR does not fulfill `Send` assert_send::<&'a Dummy+Send>(); //~ ERROR does not fulfill `Send` assert_send::>(); //~ ERROR does not fulfill `Send` // ...unless they are properly bounded assert_send::<&'static Dummy+Send>(); assert_send::>(); // but closure and object types can have lifetime bounds which make // them not ok (FIXME #5121) // assert_send::(); // ERROR does not fulfill `Send` // assert_send::>(); // ERROR does not fulfill `Send` // unsafe ptrs are ok unless they point at unsendable things assert_send::<*int>(); assert_send::<*&'a int>(); //~ ERROR does not fulfill `Send` } fn main() { }