os-rust/tests/ui/phantom-auto-trait.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

31 lines
695 B
Rust
Raw Normal View History

// Ensure that auto trait checks `T` when it encounters a `PhantomData<T>` field, instead of
// checking the `PhantomData<T>` type itself (which almost always implements an auto trait).
#![feature(auto_traits)]
2015-04-17 22:12:20 -07:00
use std::marker::{PhantomData};
unsafe auto trait Zen {}
unsafe impl<'a, T: 'a> Zen for &'a T where T: Sync {}
struct Guard<'a, T: 'a> {
_marker: PhantomData<&'a T>,
}
struct Nested<T>(T);
fn is_zen<T: Zen>(_: T) {}
fn not_sync<T>(x: Guard<T>) {
is_zen(x)
//~^ ERROR `T` cannot be shared between threads safely [E0277]
}
fn nested_not_sync<T>(x: Nested<Guard<T>>) {
is_zen(x)
//~^ ERROR `T` cannot be shared between threads safely [E0277]
}
fn main() {}