rust/tests/ui/threads-sendsync/issue-43733.rs

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

33 lines
988 B
Rust
Raw Normal View History

//@ needs-threads
2017-09-24 10:15:18 +00:00
#![feature(thread_local)]
#![feature(cfg_target_thread_local, thread_local_internals)]
2021-12-20 18:24:40 +00:00
use std::cell::RefCell;
type Foo = std::cell::RefCell<String>;
#[cfg(target_thread_local)]
2017-09-24 10:15:18 +00:00
#[thread_local]
2023-04-26 19:02:56 +00:00
static __KEY: std::thread::local_impl::Key<Foo> = std::thread::local_impl::Key::new();
#[cfg(not(target_thread_local))]
2023-04-26 19:02:56 +00:00
static __KEY: std::thread::local_impl::Key<Foo> = std::thread::local_impl::Key::new();
2021-12-20 18:24:40 +00:00
fn __getit(_: Option<&mut Option<RefCell<String>>>) -> std::option::Option<&'static Foo> {
__KEY.get(Default::default)
2023-12-07 11:56:48 +00:00
//~^ ERROR call to unsafe function `Key::<T>::get` is unsafe
}
static FOO: std::thread::LocalKey<Foo> = std::thread::LocalKey::new(__getit);
2023-12-07 11:56:48 +00:00
//~^ ERROR call to unsafe function `LocalKey::<T>::new` is unsafe
fn main() {
FOO.with(|foo| println!("{}", foo.borrow()));
std::thread::spawn(|| {
FOO.with(|foo| *foo.borrow_mut() += "foo");
})
.join()
.unwrap();
FOO.with(|foo| println!("{}", foo.borrow()));
}