blob: 0cb91247232b058df7e7ada455a076b39288faa7 (
plain)
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
#![warn(clippy::readonly_write_lock)]
use std::sync::RwLock;
fn mutate_i32(x: &mut i32) {
*x += 1;
}
fn accept_i32(_: i32) {}
fn main() {
let lock = RwLock::new(42);
let lock2 = RwLock::new(1234);
{
let writer = lock.read().unwrap();
//~^ readonly_write_lock
dbg!(&writer);
}
{
let writer = lock.read().unwrap();
//~^ readonly_write_lock
accept_i32(*writer);
}
{
let mut writer = lock.write().unwrap();
mutate_i32(&mut writer);
dbg!(&writer);
}
{
let mut writer = lock.write().unwrap();
*writer += 1;
}
{
let mut writer1 = lock.write().unwrap();
let mut writer2 = lock2.write().unwrap();
*writer2 += 1;
*writer1 = *writer2;
}
}
fn issue12733(rw: &RwLock<()>) {
let _write_guard = rw.write().unwrap();
}
|