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
type map = Memory.map
type node = Memory.node
let map kf = (Analysis.get kf).map
let id n = Memory.id n
let uid m n = Memory.id @@ Memory.node m n
let iter = Memory.iter
let find m id = Memory.node m @@ Memory.forge id
let node = Memory.node
let nodes = Memory.nodes
let equal = Memory.equal
let included = Memory.included
let separated = Memory.separated
let singleton = Memory.singleton
let size = Memory.size
let roots = Memory.roots
let labels = Memory.labels
let reads = Memory.reads
let writes = Memory.writes
let shifts = Memory.shifts
let typed = Memory.typed
let parents m n = Memory.nodes m @@ Memory.parents m n
let points_to m n = Option.map (Memory.node m) @@ Memory.points_to m n
let pointed_by m n = Memory.nodes m @@ Memory.pointed_by m n
let lval m l = Memory.node m @@ Memory.lval m l
let exp m e = Option.map (Memory.node m) @@ Memory.exp m e
let cvar = Memory.cvar
let field = Memory.field
let index = Memory.index
let = Memory.footprint