-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathalloc_example.rs
64 lines (51 loc) · 1.51 KB
/
alloc_example.rs
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
mod disk;
use disk::allocator::*;
use disk::seq_view::*;
use std::collections::HashSet;
use vstd::prelude::*;
verus! {
broadcast use vstd::std_specs::hash::group_hash_axioms;
struct Pred {
pub ghost id: int,
}
impl AllocatorPred<usize, SeqFrac<u8>> for Pred {
open spec fn pred(self, k: usize, v: SeqFrac<u8>) -> bool {
&&& v.valid(self.id)
&&& v.off() == k
&&& [email protected]() == 1
}
proof fn exclusive(self, k: usize, tracked mut v1: SeqFrac<u8>, tracked v2: SeqFrac<u8>) {
v1.disjoint(&v2);
}
}
fn main() {
let mut addrs = HashSet::<usize>::new();
addrs.insert(0);
addrs.insert(1);
addrs.insert(2);
let tracked (mut auth, mut frac) = SeqAuth::<u8>::new(seq![10, 11, 12]);
let tracked f2 = frac.split(2);
let tracked f1 = frac.split(1);
let tracked f0 = frac;
let tracked m = Map::<usize, SeqFrac<u8>>::tracked_empty();
proof {
m.tracked_insert(0, f0);
m.tracked_insert(1, f1);
m.tracked_insert(2, f2);
}
let tracked p = Pred {
id: auth.id(),
};
let mut a = Allocator::<usize, _, Pred>::new(addrs, Tracked(m), Tracked(p));
let r = a.alloc();
match r {
None => {
assert(false);
},
Some((i, tv)) => {
assert(p.pred(i, tv@));
a.free(i, tv);
},
}
}
}