Source file Datalog_expr.ml
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
65
66
67
68
69
70
71
72
73
74
75
type var = string
[@@deriving show, repr]
type 'a term =
| Const of 'a
| Var of var
[@@deriving show, repr]
type ('sym, 'a) prop = {
rel: 'sym;
args: 'a term list
}
[@@deriving show, repr]
type ('sym, 'a) sequent = {
conclusion: ('sym, 'a) prop;
premises: ('sym, 'a) prop list
}
[@@deriving show, repr]
type ('sym, 'a) script = ('sym, 'a) sequent list
[@@deriving show, repr]
type ('sym, 'a) query = {
var: var;
positives: ('sym, 'a) prop list;
negatives: ('sym, 'a) prop list
}
[@@deriving show, repr]
let map_term f = function
| Const c -> Const (f c)
| Var x -> Var x
let map_prop f g prop = {rel = f prop.rel; args = List.map (map_term g) prop.args}
let map_premises f g = List.map (map_prop f g)
let map_sequent f g sequent = {
conclusion = map_prop f g sequent.conclusion;
premises = map_premises f g sequent.premises
}
let map_script f g = List.map (map_sequent f g)
let map_query f g query = {query with
positives = map_premises f g query.positives;
negatives = map_premises f g query.negatives
}
let iter_script f script =
ignore @@ map_script Fun.id f script
let iter_query f query =
ignore @@ map_query Fun.id f query
module Constructors = struct
let const x = Const x
let var x = Var x
end
include Constructors
module Notation = struct
include Constructors
let (<<) conclusion premises = {conclusion; premises}
let (@*) rel args = {rel; args}
end