diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-17 12:02:58 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-17 12:02:58 +0000 |
commit | 698f8c2f01ea549d77d7dc3338a12e04c11057b9 (patch) | |
tree | 173a775858bd501c378080a10dca74132f05bc50 /src/test/ui/issues/issue-17718-static-unsafe-interior.rs | |
parent | Initial commit. (diff) | |
download | rustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.tar.xz rustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.zip |
Adding upstream version 1.64.0+dfsg1.upstream/1.64.0+dfsg1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/test/ui/issues/issue-17718-static-unsafe-interior.rs')
-rw-r--r-- | src/test/ui/issues/issue-17718-static-unsafe-interior.rs | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/src/test/ui/issues/issue-17718-static-unsafe-interior.rs b/src/test/ui/issues/issue-17718-static-unsafe-interior.rs new file mode 100644 index 000000000..65a8713ba --- /dev/null +++ b/src/test/ui/issues/issue-17718-static-unsafe-interior.rs @@ -0,0 +1,52 @@ +// run-pass +#![allow(dead_code)] +#![allow(unused_variables)] +#![allow(unused_imports)] +// pretty-expanded FIXME #23616 + +use std::marker; +use std::cell::UnsafeCell; + +struct MyUnsafePack<T>(UnsafeCell<T>); + +unsafe impl<T: Send> Sync for MyUnsafePack<T> {} + +struct MyUnsafe<T> { + value: MyUnsafePack<T> +} + +impl<T> MyUnsafe<T> { + fn forbidden(&self) {} +} + +unsafe impl<T: Send> Sync for MyUnsafe<T> {} + +enum UnsafeEnum<T> { + VariantSafe, + VariantUnsafe(UnsafeCell<T>) +} + +unsafe impl<T: Send> Sync for UnsafeEnum<T> {} + +static STATIC1: UnsafeEnum<isize> = UnsafeEnum::VariantSafe; + +static STATIC2: MyUnsafePack<isize> = MyUnsafePack(UnsafeCell::new(1)); +const CONST: MyUnsafePack<isize> = MyUnsafePack(UnsafeCell::new(1)); +static STATIC3: MyUnsafe<isize> = MyUnsafe{value: CONST}; + +static STATIC4: &'static MyUnsafePack<isize> = &STATIC2; + +struct Wrap<T> { + value: T +} + +unsafe impl<T: Send> Sync for Wrap<T> {} + +static UNSAFE: MyUnsafePack<isize> = MyUnsafePack(UnsafeCell::new(2)); +static WRAPPED_UNSAFE: Wrap<&'static MyUnsafePack<isize>> = Wrap { value: &UNSAFE }; + +fn main() { + let a = &STATIC1; + + STATIC3.forbidden() +} |