forked from CakeML/cakeml
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcfTacticsLib.sig
150 lines (117 loc) · 4.78 KB
/
cfTacticsLib.sig
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
signature cfTacticsLib =
sig
include Abbrev
(* Parse and normalise a program consisting of one or several toplevel
declarations *)
val process_topdecs : string quotation -> term
(* [xcf name prog_state] is usually the first tactic to call when
proving a specification.
It turns a goal corresponding to a specification of a function
named [name] in [prog_state], which is of of the form [app ...],
into a characteristic formula.
*)
val xcf : string -> ml_progLib.ml_prog_state -> tactic
val xcf_with_def : string -> thm -> tactic
(* [xpull] must be called whenever the goal is a cf which
precondition contains pure facts ([& H]); [xpull] then
extracts them and put them in the context.
*)
val xpull : tactic
(* [xsimpl] applies on goals containing heap implications
[H ==>> Q], and tries to simplify them
*)
val xsimpl : tactic
(* [xlet] applies on characteristic formulae for let and sequences,
of the form [cf_let ...].
It must be provided the post-condition for the expression bound
to the value; the introduced name will be deduced from the
variable of the lambda.
Example: [xlet `POSTv i. & INT 3 i`]
*)
val xlet : term quotation -> tactic
(* [xfun] applies on characteristic formulae for function
declaration, of the form [cf_fundecl ...] or
[cf_fundecl_rec ...].
It must be provided with a name for the closure corresponding to
the function. It then adds to the context the most general
specification for the new function, that will be used by later
calls to [xapp].
*)
val xfun : term quotation -> tactic
(* [xfun_spec] is a variant of [xfun] which allows providing
explicitly a specification for the introduced function. This
produces a subgoal for proving the asserted spec, knowing the
most-general specification, as [xfun] would produce.
This is mostly useful for recursive functions, where the general
specification is generally not useful as-is.
The first argument is a name for the introduced closure, and the
second argument is the provided specification (of the form
[app p f args H Q]).
*)
val xfun_spec : term quotation -> term quotation -> tactic
(* [xapp] and [xapp_spec] apply on characteristic fomulae for
function application, of the form [cf_app ...].
[xapp] tries to fetch a specification for the applied function
from the currently loaded theories. [xapp_spec] allows to
explicitly provide a specification for the applied function.
*)
val xapp : tactic
val xapp_spec : thm -> tactic
(* [xret] applies on characteristic formulae of the form
[cf_lit ...], [cf_con ...], [cf_var ...].
[xlit], [xcon] and [xvar] are aliases of [xret].
*)
val xret : tactic
val xlit : tactic
val xcon : tactic
val xvar : tactic
(* [xlog] applies on characteristic formulae for logical operations
(produced by [andalso] or [orelse] at source level), which are of
the form [cf_log ...].
*)
val xlog : tactic
(* [xif] applies on characteristic formulae for if..then..else, of
the form [cf_if ...].
It usually produces two subgoals, one for each branch.
*)
val xif : tactic
(* [xmatch] applies to characteristic formulae for pattern matching,
of the form [cf_match ...].
[xmatch] is expected to be called after case analysis on the
matched value has been performed in the logic, in order to
simplify the goal and reduce it to the cf of the matching branch.
*)
val xmatch : tactic
(* [xffi] applies on characteristic formulae for ffi operations, of the form
[cf_ffi ...].
*)
val xref : tactic
(* [xref] applies to characteristic formulae for applications of the "ref"
primitive, where goals are of the form [cf_ref ....]
*)
val xffi : tactic
(* [xraise] applies on characteristic formulae for raise, of the form
[cf_raise ..].
*)
val xraise : tactic
(* [xhandle] applies on characteristic formulae for exception handling,
of the form [cf_handle ..].
A post-condition for the evaluation of the body must be provided.
*)
val xhandle : term quotation -> tactic
(* [xcases] is somewhat similar to [xmatch]. It applies to characteristic
formalue of the form [cf_cases ...], and simplifies them. Such formulae are
typically produced by [xhandle].
[xcases] is not automatically called by [xhandle] as the user is expected
to pull facts using [xpull], perform case analysis, unfold representation
predicates, ..., before calling [xcases].
*)
val xcases : tactic
(* low level / debugging *)
val xlocal : tactic
val xapply : thm -> tactic
val xapp_prepare_goal : tactic
val reduce_tac : tactic
val reduce_can_pmatch_all_tac : tactic
val hide_environments : bool -> unit
end