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.

37 lines
1.1 KiB
Rust
Raw Normal View History

// ignore-wasm32
// revisions: mir thir
// [thir]compile-flags: -Z thir-unsafeck
2017-09-24 05:15:18 -05:00
#![feature(thread_local)]
#![feature(cfg_target_thread_local, thread_local_internals)]
2021-12-20 12:24:40 -06:00
use std::cell::RefCell;
type Foo = std::cell::RefCell<String>;
#[cfg(target_thread_local)]
2017-09-24 05:15:18 -05:00
#[thread_local]
2023-04-26 14:02:56 -05:00
static __KEY: std::thread::local_impl::Key<Foo> = std::thread::local_impl::Key::new();
#[cfg(not(target_thread_local))]
2023-04-26 14:02:56 -05:00
static __KEY: std::thread::local_impl::Key<Foo> = std::thread::local_impl::Key::new();
2021-12-20 12:24:40 -06:00
fn __getit(_: Option<&mut Option<RefCell<String>>>) -> std::option::Option<&'static Foo> {
__KEY.get(Default::default)
//[mir]~^ ERROR call to unsafe function is unsafe
2023-04-26 14:02:56 -05:00
//[thir]~^^ ERROR call to unsafe function `Key::<T>::get`
}
static FOO: std::thread::LocalKey<Foo> = std::thread::LocalKey::new(__getit);
//[mir]~^ ERROR call to unsafe function is unsafe
//[thir]~^^ ERROR call to unsafe function `LocalKey::<T>::new`
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()));
}