diff options
| author | Alex Crichton <alex@alexcrichton.com> | 2015-03-06 15:37:51 -0800 |
|---|---|---|
| committer | Alex Crichton <alex@alexcrichton.com> | 2015-03-06 15:37:51 -0800 |
| commit | 31af63748bbe62adab6bed6008deca67911bd0d2 (patch) | |
| tree | 9e86773c2b5fd566c638e6f8e3f5b24c341681fb /src/test | |
| parent | 697de42f69c6c437b7bd7a3298e991d1a5fc9adc (diff) | |
| parent | f0897aa17f98ff41f1eb6a3af40d84123d3d89d5 (diff) | |
| download | rust-31af63748bbe62adab6bed6008deca67911bd0d2.tar.gz rust-31af63748bbe62adab6bed6008deca67911bd0d2.zip | |
rollup merge of #23091: japaric/phantom
r? @nikomatsakis See the cfail test, it compiles without this patch cc #13231
Diffstat (limited to 'src/test')
| -rw-r--r-- | src/test/compile-fail/phantom-oibit.rs | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/src/test/compile-fail/phantom-oibit.rs b/src/test/compile-fail/phantom-oibit.rs new file mode 100644 index 00000000000..c912d084daa --- /dev/null +++ b/src/test/compile-fail/phantom-oibit.rs @@ -0,0 +1,41 @@ +// Copyright 2015 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. + +// Ensure that OIBIT checks `T` when it encounters a `PhantomData<T>` field, instead of checking +// the `PhantomData<T>` type itself (which almost always implements a "default" trait +// (`impl Trait for ..`)) + +#![feature(optin_builtin_traits)] + +use std::marker::{MarkerTrait, PhantomData}; + +unsafe trait Zen: MarkerTrait {} + +unsafe impl Zen for .. {} + +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: the trait `core::marker::Sync` is not implemented for the type `T` +} + +fn nested_not_sync<T>(x: Nested<Guard<T>>) { + is_zen(x) //~ error: the trait `core::marker::Sync` is not implemented for the type `T` +} + +fn main() {} |
