mirror of
https://github.com/rtic-rs/rtic.git
synced 2025-12-16 21:05:35 +01:00
wrap references to resources in static-ref's Ref/RefMut
to assert that they point to `static` data
This commit is contained in:
parent
4d8d53a206
commit
a94de6bafc
3 changed files with 30 additions and 23 deletions
|
|
@ -8,26 +8,26 @@ static R1: Resource<i32, C2> = Resource::new(0);
|
|||
|
||||
fn j1(mut prio: P2) {
|
||||
// OK only one `&mut-` reference to the data
|
||||
let r1: &mut i32 = R1.claim_mut(&mut prio);
|
||||
let r1 = R1.claim_mut(&mut prio);
|
||||
}
|
||||
|
||||
fn j2(prio: P2) {
|
||||
// OK two `&-` references to the same data
|
||||
let r1: &i32 = R1.claim(&prio);
|
||||
let another_r1: &i32 = R1.claim(&prio);
|
||||
let r1 = R1.claim(&prio);
|
||||
let another_r1 = R1.claim(&prio);
|
||||
}
|
||||
|
||||
fn j3(mut prio: P2) {
|
||||
// CAN'T have a `&-` reference and a `&mut-` reference to the same data
|
||||
let r1: &i32 = R1.claim(&prio);
|
||||
let another_r1: &mut i32 = R1.claim_mut(&mut prio);
|
||||
let r1 = R1.claim(&prio);
|
||||
let another_r1 = R1.claim_mut(&mut prio);
|
||||
//~^ error
|
||||
}
|
||||
|
||||
fn j4(mut prio: P2) {
|
||||
// CAN'T have two `&mut-` references to the same data
|
||||
let r1: &mut i32 = R1.claim_mut(&mut prio);
|
||||
let another_r1: &mut i32 = R1.claim_mut(&mut prio);
|
||||
let r1 = R1.claim_mut(&mut prio);
|
||||
let another_r1 = R1.claim_mut(&mut prio);
|
||||
//~^ error
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue