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
module DOMAIN : Datatype.S with type t = Code.domain =
Datatype.Make
(struct
type t = Code.domain
include Datatype.Undefined
let name = "Region.Analysis.MEMORY"
let mem_project = Datatype.never_any_project
let reprs = [ Memory.create () ]
end)
module STATE = State_builder.Hashtbl(Kernel_function.Hashtbl)(DOMAIN)
(struct
let size = 0
let name = "Region.Analysis.STATE"
let dependencies = [Ast.self]
end)
let find = STATE.find
let get kf =
try STATE.find kf with Not_found ->
Options.feedback ~ontty:`Transient
"Function %a%t" Kernel_function.pretty kf Unicode.pp_ellipsis ;
let domain = Code.domain kf in
STATE.add kf domain ;
domain
let compute kf = ignore @@ get kf
let add_hook f = STATE.add_hook_on_change (fun _ -> f())