File: suggest-cell.rs

package info (click to toggle)
rustc 1.85.0%2Bdfsg3-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental, sid, trixie
  • size: 893,396 kB
  • sloc: xml: 158,127; python: 35,830; javascript: 19,497; cpp: 19,002; sh: 17,245; ansic: 13,127; asm: 4,376; makefile: 1,051; perl: 29; lisp: 29; ruby: 19; sql: 11
file content (31 lines) | stat: -rw-r--r-- 1,691 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
fn require_sync<T: Sync>() {}
//~^ NOTE required by this bound in `require_sync`
//~| NOTE required by this bound in `require_sync`
//~| NOTE required by this bound in `require_sync`
//~| NOTE required by this bound in `require_sync`
//~| NOTE required by a bound in `require_sync`
//~| NOTE required by a bound in `require_sync`
//~| NOTE required by a bound in `require_sync`
//~| NOTE required by a bound in `require_sync`

fn main() {
    require_sync::<std::cell::Cell<()>>();
    //~^ ERROR `Cell<()>` cannot be shared between threads safely
    //~| NOTE `Cell<()>` cannot be shared between threads safely
    //~| NOTE if you want to do aliasing and mutation between multiple threads, use `std::sync::RwLock`

    require_sync::<std::cell::Cell<u8>>();
    //~^ ERROR `Cell<u8>` cannot be shared between threads safely
    //~| NOTE `Cell<u8>` cannot be shared between threads safely
    //~| NOTE if you want to do aliasing and mutation between multiple threads, use `std::sync::RwLock` or `std::sync::atomic::AtomicU8` instead

    require_sync::<std::cell::Cell<i32>>();
    //~^ ERROR `Cell<i32>` cannot be shared between threads safely
    //~| NOTE `Cell<i32>` cannot be shared between threads safely
    //~| NOTE if you want to do aliasing and mutation between multiple threads, use `std::sync::RwLock` or `std::sync::atomic::AtomicI32` instead

    require_sync::<std::cell::Cell<bool>>();
    //~^ ERROR `Cell<bool>` cannot be shared between threads safely
    //~| NOTE `Cell<bool>` cannot be shared between threads safely
    //~| NOTE if you want to do aliasing and mutation between multiple threads, use `std::sync::RwLock` or `std::sync::atomic::AtomicBool` instead
}