mirror of
https://github.com/rust-lang/rust.git
synced 2024-12-02 11:44:28 +00:00
5828910ff4
This allows removing all the platform-dependent code from `library/std/src/thread/local.rs` and `library/std/src/thread/mod.rs` Signed-off-by: Ayush Singh <ayushsingh1325@gmail.com>
39 lines
1.3 KiB
Rust
39 lines
1.3 KiB
Rust
// ignore-wasm32
|
|
// revisions: mir thir
|
|
// [thir]compile-flags: -Z thir-unsafeck
|
|
// normalize-stderr-test: "__LocalKeyInner::<T>::get" -> "$$LOCALKEYINNER::<T>::get"
|
|
// normalize-stderr-test: "__LocalKeyInner::<T>::get" -> "$$LOCALKEYINNER::<T>::get"
|
|
#![feature(thread_local)]
|
|
#![feature(cfg_target_thread_local, thread_local_internals)]
|
|
|
|
use std::cell::RefCell;
|
|
|
|
type Foo = std::cell::RefCell<String>;
|
|
|
|
#[cfg(target_thread_local)]
|
|
#[thread_local]
|
|
static __KEY: std::thread::__LocalKeyInner<Foo> = std::thread::__LocalKeyInner::new();
|
|
|
|
#[cfg(not(target_thread_local))]
|
|
static __KEY: std::thread::__LocalKeyInner<Foo> = std::thread::__LocalKeyInner::new();
|
|
|
|
fn __getit(_: Option<&mut Option<RefCell<String>>>) -> std::option::Option<&'static Foo> {
|
|
__KEY.get(Default::default)
|
|
//[mir]~^ ERROR call to unsafe function is unsafe
|
|
//[thir]~^^ ERROR call to unsafe function `__
|
|
}
|
|
|
|
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()));
|
|
}
|