blob: 76f4a43ae530015d9dbeafe4ca0770c84c4798e2 (
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
|
#![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();
//~^ ERROR: this write lock is used only for reading
//~| NOTE: `-D clippy::readonly-write-lock` implied by `-D warnings`
dbg!(&writer);
}
{
let writer = lock.read().unwrap();
//~^ ERROR: this write lock is used only for reading
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;
}
}
|