author | wenzelm |
Thu, 29 Jun 2017 11:42:42 +0200 | |
changeset 66212 | f41396c15bb1 |
parent 63073 | 413184c7a2a2 |
child 69593 | 3dda49e08b9d |
permissions | -rw-r--r-- |
33265 | 1 |
(* Title: HOL/Tools/Predicate_Compile/predicate_compile.ML |
2 |
Author: Lukas Bulwahn, TU Muenchen |
|
32668
b2de45007537
added first prototype of the extended predicate compiler
bulwahn
parents:
diff
changeset
|
3 |
|
41941 | 4 |
Entry point for the predicate compiler; definition of Toplevel |
5 |
commands code_pred and values. |
|
32668
b2de45007537
added first prototype of the extended predicate compiler
bulwahn
parents:
diff
changeset
|
6 |
*) |
33265 | 7 |
|
32668
b2de45007537
added first prototype of the extended predicate compiler
bulwahn
parents:
diff
changeset
|
8 |
signature PREDICATE_COMPILE = |
b2de45007537
added first prototype of the extended predicate compiler
bulwahn
parents:
diff
changeset
|
9 |
sig |
36050
88203782cf12
activating the signature of Predicate_Compile again which was deactivated in changeset d93a3cb55068 for debugging purposes
bulwahn
parents:
36032
diff
changeset
|
10 |
val preprocess : Predicate_Compile_Aux.options -> term -> theory -> theory |
36023
d606ca1674a7
adding a hook for experiments in the predicate compilation process
bulwahn
parents:
36022
diff
changeset
|
11 |
val intro_hook : (theory -> thm -> unit) option Unsynchronized.ref |
32668
b2de45007537
added first prototype of the extended predicate compiler
bulwahn
parents:
diff
changeset
|
12 |
end; |
b2de45007537
added first prototype of the extended predicate compiler
bulwahn
parents:
diff
changeset
|
13 |
|
36050
88203782cf12
activating the signature of Predicate_Compile again which was deactivated in changeset d93a3cb55068 for debugging purposes
bulwahn
parents:
36032
diff
changeset
|
14 |
structure Predicate_Compile : PREDICATE_COMPILE = |
32668
b2de45007537
added first prototype of the extended predicate compiler
bulwahn
parents:
diff
changeset
|
15 |
struct |
b2de45007537
added first prototype of the extended predicate compiler
bulwahn
parents:
diff
changeset
|
16 |
|
36023
d606ca1674a7
adding a hook for experiments in the predicate compilation process
bulwahn
parents:
36022
diff
changeset
|
17 |
val intro_hook = Unsynchronized.ref NONE : (theory -> thm -> unit) option Unsynchronized.ref |
d606ca1674a7
adding a hook for experiments in the predicate compilation process
bulwahn
parents:
36022
diff
changeset
|
18 |
|
32668
b2de45007537
added first prototype of the extended predicate compiler
bulwahn
parents:
diff
changeset
|
19 |
open Predicate_Compile_Aux; |
b2de45007537
added first prototype of the extended predicate compiler
bulwahn
parents:
diff
changeset
|
20 |
|
33125 | 21 |
fun print_intross options thy msg intross = |
22 |
if show_intermediate_results options then |
|
55437 | 23 |
tracing (msg ^ |
55628 | 24 |
(cat_lines (map |
33376
5cb663aa48ee
predicate compiler creates code equations for predicates with full mode
bulwahn
parents:
33375
diff
changeset
|
25 |
(fn (c, intros) => "Introduction rule(s) of " ^ c ^ ":\n" ^ |
61268 | 26 |
commas (map (Thm.string_of_thm_global thy) intros)) intross))) |
33125 | 27 |
else () |
55437 | 28 |
|
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
29 |
fun print_specs options thy specs = |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
30 |
if show_intermediate_results options then |
55437 | 31 |
map (fn (c, thms) => |
32 |
"Constant " ^ c ^ " has specification:\n" ^ |
|
61268 | 33 |
(cat_lines (map (Thm.string_of_thm_global thy) thms)) ^ "\n") specs |
55628 | 34 |
|> cat_lines |> tracing |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
35 |
else () |
55437 | 36 |
|
51685
385ef6706252
more standard module name Axclass (according to file name);
wenzelm
parents:
50056
diff
changeset
|
37 |
fun overload_const thy s = the_default s (Option.map fst (Axclass.inst_of_param thy s)) |
33404 | 38 |
|
33146
bf852ef586f2
now the predicate compilere handles the predicate without introduction rules better as before
bulwahn
parents:
33142
diff
changeset
|
39 |
fun map_specs f specs = |
bf852ef586f2
now the predicate compilere handles the predicate without introduction rules better as before
bulwahn
parents:
33142
diff
changeset
|
40 |
map (fn (s, ths) => (s, f ths)) specs |
bf852ef586f2
now the predicate compilere handles the predicate without introduction rules better as before
bulwahn
parents:
33142
diff
changeset
|
41 |
|
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
42 |
fun process_specification options specs thy' = |
33121
9b10dc5da0e0
added to process higher-order arguments by adding new constants
bulwahn
parents:
33120
diff
changeset
|
43 |
let |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
44 |
val _ = print_step options "Compiling predicates to flat introrules..." |
55437 | 45 |
val specs = |
46 |
map |
|
47 |
(apsnd (map |
|
48 |
(fn th => |
|
49 |
if is_equationlike th then Predicate_Compile_Data.normalize_equation thy' th else th))) |
|
50 |
specs |
|
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
51 |
val (intross1, thy'') = |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
52 |
apfst flat (fold_map (Predicate_Compile_Pred.preprocess options) specs thy') |
33125 | 53 |
val _ = print_intross options thy'' "Flattened introduction rules: " intross1 |
33129
3085da75ed54
changed import_intros to handle parameters differently; changed handling of higher-order function compilation; reverted MicroJava change; tuned
bulwahn
parents:
33127
diff
changeset
|
54 |
val _ = print_step options "Replacing functions in introrules..." |
33121
9b10dc5da0e0
added to process higher-order arguments by adding new constants
bulwahn
parents:
33120
diff
changeset
|
55 |
val intross2 = |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
56 |
if function_flattening options then |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
57 |
if fail_safe_function_flattening options then |
55437 | 58 |
(case try (map_specs (maps (Predicate_Compile_Fun.rewrite_intro thy''))) intross1 of |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
59 |
SOME intross => intross |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
60 |
| NONE => |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
61 |
(if show_caught_failures options then tracing "Function replacement failed!" else (); |
55437 | 62 |
intross1)) |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
63 |
else map_specs (maps (Predicate_Compile_Fun.rewrite_intro thy'')) intross1 |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
64 |
else |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
65 |
intross1 |
33125 | 66 |
val _ = print_intross options thy'' "Introduction rules with replaced functions: " intross2 |
55437 | 67 |
val _ = print_step options |
68 |
"Introducing new constants for abstractions at higher-order argument positions..." |
|
69 |
val (intross3, (new_defs, thy''')) = |
|
70 |
Predicate_Compile_Pred.flat_higher_order_arguments (intross2, thy'') |
|
71 |
val (new_intross, thy'''') = |
|
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
72 |
if not (null new_defs) then |
33404 | 73 |
let |
55437 | 74 |
val _ = |
75 |
print_step options "Recursively obtaining introduction rules for new definitions..." |
|
33404 | 76 |
in process_specification options new_defs thy''' end |
77 |
else ([], thy''') |
|
33121
9b10dc5da0e0
added to process higher-order arguments by adding new constants
bulwahn
parents:
33120
diff
changeset
|
78 |
in |
9b10dc5da0e0
added to process higher-order arguments by adding new constants
bulwahn
parents:
33120
diff
changeset
|
79 |
(intross3 @ new_intross, thy'''') |
9b10dc5da0e0
added to process higher-order arguments by adding new constants
bulwahn
parents:
33120
diff
changeset
|
80 |
end |
9b10dc5da0e0
added to process higher-order arguments by adding new constants
bulwahn
parents:
33120
diff
changeset
|
81 |
|
34948
2d5f2a9f7601
refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents:
33752
diff
changeset
|
82 |
fun preprocess_strong_conn_constnames options gr ts thy = |
55437 | 83 |
if forall (fn (Const (c, _)) => Core_Data.is_registered (Proof_Context.init_global thy) c) ts |
84 |
then thy |
|
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
85 |
else |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
86 |
let |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
87 |
fun get_specs ts = map_filter (fn t => |
35404 | 88 |
Term_Graph.get_node gr t |> |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
89 |
(fn ths => if null ths then NONE else SOME (fst (dest_Const t), ths))) |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
90 |
ts |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
91 |
val _ = print_step options ("Preprocessing scc of " ^ |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
92 |
commas (map (Syntax.string_of_term_global thy) ts)) |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
93 |
val (prednames, funnames) = List.partition (fn t => body_type (fastype_of t) = @{typ bool}) ts |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
94 |
(* untangle recursion by defining predicates for all functions *) |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
95 |
val _ = print_step options |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
96 |
("Compiling functions (" ^ commas (map (Syntax.string_of_term_global thy) funnames) ^ |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
97 |
") to predicates...") |
36032
dfd30b5b4e73
adding specialisation of predicates to the predicate compiler
bulwahn
parents:
36027
diff
changeset
|
98 |
val (fun_pred_specs, thy1) = |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
99 |
(if function_flattening options andalso (not (null funnames)) then |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
100 |
if fail_safe_function_flattening options then |
55437 | 101 |
(case try (Predicate_Compile_Fun.define_predicates (get_specs funnames)) thy of |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
102 |
SOME (intross, thy) => (intross, thy) |
55437 | 103 |
| NONE => ([], thy)) |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
104 |
else Predicate_Compile_Fun.define_predicates (get_specs funnames) thy |
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
105 |
else ([], thy)) |
36032
dfd30b5b4e73
adding specialisation of predicates to the predicate compiler
bulwahn
parents:
36027
diff
changeset
|
106 |
val _ = print_specs options thy1 fun_pred_specs |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
107 |
val specs = (get_specs prednames) @ fun_pred_specs |
36032
dfd30b5b4e73
adding specialisation of predicates to the predicate compiler
bulwahn
parents:
36027
diff
changeset
|
108 |
val (intross3, thy2) = process_specification options specs thy1 |
dfd30b5b4e73
adding specialisation of predicates to the predicate compiler
bulwahn
parents:
36027
diff
changeset
|
109 |
val _ = print_intross options thy2 "Introduction rules with new constants: " intross3 |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
110 |
val intross4 = map_specs (maps remove_pointless_clauses) intross3 |
36032
dfd30b5b4e73
adding specialisation of predicates to the predicate compiler
bulwahn
parents:
36027
diff
changeset
|
111 |
val _ = print_intross options thy2 "After removing pointless clauses: " intross4 |
dfd30b5b4e73
adding specialisation of predicates to the predicate compiler
bulwahn
parents:
36027
diff
changeset
|
112 |
val intross5 = map_specs (map (remove_equalities thy2)) intross4 |
dfd30b5b4e73
adding specialisation of predicates to the predicate compiler
bulwahn
parents:
36027
diff
changeset
|
113 |
val _ = print_intross options thy2 "After removing equality premises:" intross5 |
36022
c0fa8499e366
removing simple equalities in introduction rules in the predicate compiler
bulwahn
parents:
36004
diff
changeset
|
114 |
val intross6 = |
63073
413184c7a2a2
clarified context, notably for internal use of Simplifier;
wenzelm
parents:
62969
diff
changeset
|
115 |
map (fn (s, ths) => |
413184c7a2a2
clarified context, notably for internal use of Simplifier;
wenzelm
parents:
62969
diff
changeset
|
116 |
(overload_const thy2 s, map (Axclass.overload (Proof_Context.init_global thy2)) ths)) |
413184c7a2a2
clarified context, notably for internal use of Simplifier;
wenzelm
parents:
62969
diff
changeset
|
117 |
intross5 |
36032
dfd30b5b4e73
adding specialisation of predicates to the predicate compiler
bulwahn
parents:
36027
diff
changeset
|
118 |
val intross7 = map_specs (map (expand_tuples thy2)) intross6 |
dfd30b5b4e73
adding specialisation of predicates to the predicate compiler
bulwahn
parents:
36027
diff
changeset
|
119 |
val intross8 = map_specs (map (eta_contract_ho_arguments thy2)) intross7 |
55437 | 120 |
val _ = (case !intro_hook of NONE => () | SOME f => (map_specs (map (f thy2)) intross8; ())) |
121 |
val _ = |
|
122 |
print_step options ("Looking for specialisations in " ^ commas (map fst intross8) ^ "...") |
|
36248
9ed1a37de465
added option for specialisation to the predicate compiler
bulwahn
parents:
36246
diff
changeset
|
123 |
val (intross9, thy3) = |
9ed1a37de465
added option for specialisation to the predicate compiler
bulwahn
parents:
36246
diff
changeset
|
124 |
if specialise options then |
9ed1a37de465
added option for specialisation to the predicate compiler
bulwahn
parents:
36246
diff
changeset
|
125 |
Predicate_Compile_Specialisation.find_specialisations [] intross8 thy2 |
9ed1a37de465
added option for specialisation to the predicate compiler
bulwahn
parents:
36246
diff
changeset
|
126 |
else (intross8, thy2) |
36246
43fecedff8cf
added peephole optimisations to the predicate compiler; added structure Predicate_Compile_Simps for peephole optimisations
bulwahn
parents:
36050
diff
changeset
|
127 |
val _ = print_intross options thy3 "introduction rules after specialisations: " intross9 |
43fecedff8cf
added peephole optimisations to the predicate compiler; added structure Predicate_Compile_Simps for peephole optimisations
bulwahn
parents:
36050
diff
changeset
|
128 |
val intross10 = map_specs (map_filter (peephole_optimisation thy3)) intross9 |
43fecedff8cf
added peephole optimisations to the predicate compiler; added structure Predicate_Compile_Simps for peephole optimisations
bulwahn
parents:
36050
diff
changeset
|
129 |
val _ = print_intross options thy3 "introduction rules before registering: " intross10 |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
130 |
val _ = print_step options "Registering introduction rules..." |
40053
3fa49ea76cbb
using a signature in core_data and moving some more functions to core_data
bulwahn
parents:
40048
diff
changeset
|
131 |
val thy4 = fold Core_Data.register_intros intross10 thy3 |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
132 |
in |
36032
dfd30b5b4e73
adding specialisation of predicates to the predicate compiler
bulwahn
parents:
36027
diff
changeset
|
133 |
thy4 |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
134 |
end; |
32668
b2de45007537
added first prototype of the extended predicate compiler
bulwahn
parents:
diff
changeset
|
135 |
|
34948
2d5f2a9f7601
refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents:
33752
diff
changeset
|
136 |
fun preprocess options t thy = |
32672
90f3ce5d27ae
added first version of quickcheck based on the predicate compiler; added a few quickcheck examples
bulwahn
parents:
32669
diff
changeset
|
137 |
let |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
138 |
val _ = print_step options "Fetching definitions from theory..." |
55437 | 139 |
val gr = |
140 |
cond_timeit (Config.get_global thy Quickcheck.timing) "preprocess-obtain graph" |
|
141 |
(fn () => |
|
142 |
Predicate_Compile_Data.obtain_specification_graph options thy t |
|
46614
165886a4fe64
clarified Graph.restrict (formerly Graph.subgraph) based on public graph operations;
wenzelm
parents:
42361
diff
changeset
|
143 |
|> (fn gr => Term_Graph.restrict (member (op =) (Term_Graph.all_succs gr [t])) gr)) |
34948
2d5f2a9f7601
refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents:
33752
diff
changeset
|
144 |
in |
42088
8d00484551fe
making quickcheck's result value more formal; allowing more result information to be returned after timeout; adding output of timing information in quickcheck
bulwahn
parents:
42011
diff
changeset
|
145 |
cond_timeit (Config.get_global thy Quickcheck.timing) "preprocess-process" |
55437 | 146 |
(fn () => |
147 |
fold_rev (preprocess_strong_conn_constnames options gr) |
|
148 |
(Term_Graph.strong_conn gr) thy) |
|
32672
90f3ce5d27ae
added first version of quickcheck based on the predicate compiler; added a few quickcheck examples
bulwahn
parents:
32669
diff
changeset
|
149 |
end |
90f3ce5d27ae
added first version of quickcheck based on the predicate compiler; added a few quickcheck examples
bulwahn
parents:
32669
diff
changeset
|
150 |
|
39382
c797f3ab2ae1
proposed modes for code_pred now supports modes for mutual predicates
bulwahn
parents:
38757
diff
changeset
|
151 |
datatype proposed_modes = Multiple_Preds of (string * (mode * string option) list) list |
c797f3ab2ae1
proposed modes for code_pred now supports modes for mutual predicates
bulwahn
parents:
38757
diff
changeset
|
152 |
| Single_Pred of (mode * string option) list |
c797f3ab2ae1
proposed modes for code_pred now supports modes for mutual predicates
bulwahn
parents:
38757
diff
changeset
|
153 |
|
c797f3ab2ae1
proposed modes for code_pred now supports modes for mutual predicates
bulwahn
parents:
38757
diff
changeset
|
154 |
fun extract_options lthy (((expected_modes, proposed_modes), (compilation, raw_options)), const) = |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
155 |
let |
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
156 |
fun chk s = member (op =) raw_options s |
55437 | 157 |
val proposed_modes = |
158 |
(case proposed_modes of |
|
159 |
Single_Pred proposed_modes => [(const, proposed_modes)] |
|
160 |
| Multiple_Preds proposed_modes => |
|
161 |
map (apfst (Code.read_const (Proof_Context.theory_of lthy))) proposed_modes) |
|
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
162 |
in |
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
163 |
Options { |
33623
4ec42d38224f
changed modes to expected_modes; added UNION to code_pred_inlining; fixed some examples; tuned
bulwahn
parents:
33620
diff
changeset
|
164 |
expected_modes = Option.map (pair const) expected_modes, |
55437 | 165 |
proposed_modes = |
39382
c797f3ab2ae1
proposed modes for code_pred now supports modes for mutual predicates
bulwahn
parents:
38757
diff
changeset
|
166 |
map (apsnd (map fst)) proposed_modes, |
33623
4ec42d38224f
changed modes to expected_modes; added UNION to code_pred_inlining; fixed some examples; tuned
bulwahn
parents:
33620
diff
changeset
|
167 |
proposed_names = |
39382
c797f3ab2ae1
proposed modes for code_pred now supports modes for mutual predicates
bulwahn
parents:
38757
diff
changeset
|
168 |
maps (fn (predname, ms) => (map_filter |
50056 | 169 |
(fn (_, NONE) => NONE | (m, SOME name) => SOME ((predname, m), name))) ms) proposed_modes, |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
170 |
show_steps = chk "show_steps", |
33125 | 171 |
show_intermediate_results = chk "show_intermediate_results", |
33127 | 172 |
show_proof_trace = chk "show_proof_trace", |
33251 | 173 |
show_modes = chk "show_modes", |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
174 |
show_mode_inference = chk "show_mode_inference", |
33139
9c01ee6f8ee9
added skip_proof option; playing with compilation of depth-limited predicates
bulwahn
parents:
33134
diff
changeset
|
175 |
show_compilation = chk "show_compilation", |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
176 |
show_caught_failures = false, |
39383
ddfafa97da2f
adding option show_invalid_clauses for a more detailed message when modes are not inferred
bulwahn
parents:
39382
diff
changeset
|
177 |
show_invalid_clauses = chk "show_invalid_clauses", |
33139
9c01ee6f8ee9
added skip_proof option; playing with compilation of depth-limited predicates
bulwahn
parents:
33134
diff
changeset
|
178 |
skip_proof = chk "skip_proof", |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
179 |
function_flattening = not (chk "no_function_flattening"), |
36248
9ed1a37de465
added option for specialisation to the predicate compiler
bulwahn
parents:
36246
diff
changeset
|
180 |
specialise = chk "specialise", |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
181 |
fail_safe_function_flattening = false, |
35381
5038f36b5ea1
adding no_topmost_reordering as new option to the code_pred command
bulwahn
parents:
35324
diff
changeset
|
182 |
no_topmost_reordering = (chk "no_topmost_reordering"), |
35324
c9f428269b38
adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents:
34948
diff
changeset
|
183 |
no_higher_order_predicate = [], |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
184 |
inductify = chk "inductify", |
36254 | 185 |
detect_switches = chk "detect_switches", |
40048
f3a46d524101
adding option smart_depth_limiting to predicate compiler
bulwahn
parents:
39383
diff
changeset
|
186 |
smart_depth_limiting = chk "smart_depth_limiting", |
34948
2d5f2a9f7601
refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents:
33752
diff
changeset
|
187 |
compilation = compilation |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
188 |
} |
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
189 |
end |
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
190 |
|
33623
4ec42d38224f
changed modes to expected_modes; added UNION to code_pred_inlining; fixed some examples; tuned
bulwahn
parents:
33620
diff
changeset
|
191 |
fun code_pred_cmd (((expected_modes, proposed_modes), raw_options), raw_const) lthy = |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
192 |
let |
42361 | 193 |
val thy = Proof_Context.theory_of lthy |
33132
07efd452a698
moved argument expected_modes into options; improved mode check to only check mode of the named predicate
bulwahn
parents:
33131
diff
changeset
|
194 |
val const = Code.read_const thy raw_const |
34948
2d5f2a9f7601
refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents:
33752
diff
changeset
|
195 |
val T = Sign.the_const_type thy const |
2d5f2a9f7601
refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents:
33752
diff
changeset
|
196 |
val t = Const (const, T) |
39382
c797f3ab2ae1
proposed modes for code_pred now supports modes for mutual predicates
bulwahn
parents:
38757
diff
changeset
|
197 |
val options = extract_options lthy (((expected_modes, proposed_modes), raw_options), const) |
33132
07efd452a698
moved argument expected_modes into options; improved mode check to only check mode of the named predicate
bulwahn
parents:
33131
diff
changeset
|
198 |
in |
38757
2b3e054ae6fc
renamed Local_Theory.theory(_result) to Local_Theory.background_theory(_result) to emphasize that this belongs to the infrastructure and is rarely appropriate in user-space tools;
wenzelm
parents:
38664
diff
changeset
|
199 |
if is_inductify options then |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
200 |
let |
38757
2b3e054ae6fc
renamed Local_Theory.theory(_result) to Local_Theory.background_theory(_result) to emphasize that this belongs to the infrastructure and is rarely appropriate in user-space tools;
wenzelm
parents:
38664
diff
changeset
|
201 |
val lthy' = Local_Theory.background_theory (preprocess options t) lthy |
33623
4ec42d38224f
changed modes to expected_modes; added UNION to code_pred_inlining; fixed some examples; tuned
bulwahn
parents:
33620
diff
changeset
|
202 |
val const = |
55437 | 203 |
(case Predicate_Compile_Fun.pred_of_function (Proof_Context.theory_of lthy') const of |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
204 |
SOME c => c |
55437 | 205 |
| NONE => const) |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
206 |
val _ = print_step options "Starting Predicate Compile Core..." |
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
207 |
in |
33132
07efd452a698
moved argument expected_modes into options; improved mode check to only check mode of the named predicate
bulwahn
parents:
33131
diff
changeset
|
208 |
Predicate_Compile_Core.code_pred options const lthy' |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
209 |
end |
55437 | 210 |
else Predicate_Compile_Core.code_pred_cmd options raw_const lthy |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
211 |
end |
32668
b2de45007537
added first prototype of the extended predicate compiler
bulwahn
parents:
diff
changeset
|
212 |
|
b2de45007537
added first prototype of the extended predicate compiler
bulwahn
parents:
diff
changeset
|
213 |
|
33478
b70fe083694d
moved values command from core to predicate compile
bulwahn
parents:
33475
diff
changeset
|
214 |
(* Parser for mode annotations *) |
33327 | 215 |
|
33625
eefee41ede3a
removed deprecated mode annotation parser; renamed accepted mode annotation parser to nicer naming
bulwahn
parents:
33623
diff
changeset
|
216 |
fun parse_mode_basic_expr xs = |
eefee41ede3a
removed deprecated mode annotation parser; renamed accepted mode annotation parser to nicer naming
bulwahn
parents:
33623
diff
changeset
|
217 |
(Args.$$$ "i" >> K Input || Args.$$$ "o" >> K Output || |
eefee41ede3a
removed deprecated mode annotation parser; renamed accepted mode annotation parser to nicer naming
bulwahn
parents:
33623
diff
changeset
|
218 |
Args.$$$ "bool" >> K Bool || Args.$$$ "(" |-- parse_mode_expr --| Args.$$$ ")") xs |
eefee41ede3a
removed deprecated mode annotation parser; renamed accepted mode annotation parser to nicer naming
bulwahn
parents:
33623
diff
changeset
|
219 |
and parse_mode_tuple_expr xs = |
55437 | 220 |
(parse_mode_basic_expr --| (Args.$$$ "*" || Args.$$$ "\<times>") -- parse_mode_tuple_expr >> Pair || |
221 |
parse_mode_basic_expr) xs |
|
33625
eefee41ede3a
removed deprecated mode annotation parser; renamed accepted mode annotation parser to nicer naming
bulwahn
parents:
33623
diff
changeset
|
222 |
and parse_mode_expr xs = |
55437 | 223 |
(parse_mode_tuple_expr --| (Args.$$$ "=>" || Args.$$$ "\<Rightarrow>") -- parse_mode_expr >> Fun || |
224 |
parse_mode_tuple_expr) xs |
|
33619
d93a3cb55068
first steps towards a new mode datastructure; new syntax for mode annotations and new output of modes
bulwahn
parents:
33481
diff
changeset
|
225 |
|
33625
eefee41ede3a
removed deprecated mode annotation parser; renamed accepted mode annotation parser to nicer naming
bulwahn
parents:
33623
diff
changeset
|
226 |
val mode_and_opt_proposal = parse_mode_expr -- |
62969 | 227 |
Scan.optional (Args.$$$ "as" |-- Parse.name >> SOME) NONE |
33620
b6bf2dc5aed7
added interface of user proposals for names of generated constants
bulwahn
parents:
33619
diff
changeset
|
228 |
|
39382
c797f3ab2ae1
proposed modes for code_pred now supports modes for mutual predicates
bulwahn
parents:
38757
diff
changeset
|
229 |
|
33114
4785ef554dcc
added further examples; added mode to code_pred command; tuned; some temporary things in Predicate_Compile_ex
bulwahn
parents:
33113
diff
changeset
|
230 |
val opt_modes = |
46949 | 231 |
Scan.optional (@{keyword "("} |-- Args.$$$ "modes" |-- @{keyword ":"} |-- |
62969 | 232 |
(((Parse.enum1 "and" (Parse.name --| @{keyword ":"} -- |
39382
c797f3ab2ae1
proposed modes for code_pred now supports modes for mutual predicates
bulwahn
parents:
38757
diff
changeset
|
233 |
(Parse.enum "," mode_and_opt_proposal))) >> Multiple_Preds) |
c797f3ab2ae1
proposed modes for code_pred now supports modes for mutual predicates
bulwahn
parents:
38757
diff
changeset
|
234 |
|| ((Parse.enum "," mode_and_opt_proposal) >> Single_Pred)) |
46949 | 235 |
--| @{keyword ")"}) (Multiple_Preds []) |
33623
4ec42d38224f
changed modes to expected_modes; added UNION to code_pred_inlining; fixed some examples; tuned
bulwahn
parents:
33620
diff
changeset
|
236 |
|
4ec42d38224f
changed modes to expected_modes; added UNION to code_pred_inlining; fixed some examples; tuned
bulwahn
parents:
33620
diff
changeset
|
237 |
val opt_expected_modes = |
46949 | 238 |
Scan.optional (@{keyword "("} |-- Args.$$$ "expected_modes" |-- @{keyword ":"} |-- |
239 |
Parse.enum "," parse_mode_expr --| @{keyword ")"} >> SOME) NONE |
|
33114
4785ef554dcc
added further examples; added mode to code_pred command; tuned; some temporary things in Predicate_Compile_ex
bulwahn
parents:
33113
diff
changeset
|
240 |
|
55437 | 241 |
|
33478
b70fe083694d
moved values command from core to predicate compile
bulwahn
parents:
33475
diff
changeset
|
242 |
(* Parser for options *) |
b70fe083694d
moved values command from core to predicate compile
bulwahn
parents:
33475
diff
changeset
|
243 |
|
b70fe083694d
moved values command from core to predicate compile
bulwahn
parents:
33475
diff
changeset
|
244 |
val scan_options = |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
245 |
let |
33478
b70fe083694d
moved values command from core to predicate compile
bulwahn
parents:
33475
diff
changeset
|
246 |
val scan_bool_option = foldl1 (op ||) (map Args.$$$ bool_options) |
34948
2d5f2a9f7601
refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents:
33752
diff
changeset
|
247 |
val scan_compilation = foldl1 (op ||) (map (fn (s, c) => Args.$$$ s >> K c) compilation_names) |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
248 |
in |
46949 | 249 |
Scan.optional (@{keyword "["} |-- Scan.optional scan_compilation Pred |
250 |
-- Parse.enum "," scan_bool_option --| @{keyword "]"}) |
|
34948
2d5f2a9f7601
refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents:
33752
diff
changeset
|
251 |
(Pred, []) |
33123
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
252 |
end |
3c7c4372f9ad
cleaned up debugging messages; added options to code_pred command
bulwahn
parents:
33122
diff
changeset
|
253 |
|
36960
01594f816e3a
prefer structure Keyword, Parse, Parse_Spec, Outer_Syntax;
wenzelm
parents:
36254
diff
changeset
|
254 |
val opt_print_modes = |
62969 | 255 |
Scan.optional (@{keyword "("} |-- Parse.!!! (Scan.repeat1 Parse.name --| @{keyword ")"})) [] |
33478
b70fe083694d
moved values command from core to predicate compile
bulwahn
parents:
33475
diff
changeset
|
256 |
|
46949 | 257 |
val opt_mode = (Args.$$$ "_" >> K NONE) || (parse_mode_expr >> SOME) |
33479
428ddcc16e7b
added optional mode annotations for parameters in the values command
bulwahn
parents:
33478
diff
changeset
|
258 |
|
46949 | 259 |
val opt_param_modes = Scan.optional (@{keyword "["} |-- Args.$$$ "mode" |-- @{keyword ":"} |-- |
260 |
Parse.enum ", " opt_mode --| @{keyword "]"} >> SOME) NONE |
|
33479
428ddcc16e7b
added optional mode annotations for parameters in the values command
bulwahn
parents:
33478
diff
changeset
|
261 |
|
36027
29a15da9c63d
added statistics to values command for random generation
bulwahn
parents:
36023
diff
changeset
|
262 |
val stats = Scan.optional (Args.$$$ "stats" >> K true) false |
29a15da9c63d
added statistics to values command for random generation
bulwahn
parents:
36023
diff
changeset
|
263 |
|
33478
b70fe083694d
moved values command from core to predicate compile
bulwahn
parents:
33475
diff
changeset
|
264 |
val value_options = |
b70fe083694d
moved values command from core to predicate compile
bulwahn
parents:
33475
diff
changeset
|
265 |
let |
36960
01594f816e3a
prefer structure Keyword, Parse, Parse_Spec, Outer_Syntax;
wenzelm
parents:
36254
diff
changeset
|
266 |
val expected_values = Scan.optional (Args.$$$ "expected" |-- Parse.term >> SOME) NONE |
34948
2d5f2a9f7601
refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents:
33752
diff
changeset
|
267 |
val scan_compilation = |
2d5f2a9f7601
refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents:
33752
diff
changeset
|
268 |
Scan.optional |
2d5f2a9f7601
refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents:
33752
diff
changeset
|
269 |
(foldl1 (op ||) |
36960
01594f816e3a
prefer structure Keyword, Parse, Parse_Spec, Outer_Syntax;
wenzelm
parents:
36254
diff
changeset
|
270 |
(map (fn (s, c) => Args.$$$ s -- Parse.enum "," Parse.int >> (fn (_, ps) => (c, ps))) |
34948
2d5f2a9f7601
refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents:
33752
diff
changeset
|
271 |
compilation_names)) |
2d5f2a9f7601
refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents:
33752
diff
changeset
|
272 |
(Pred, []) |
33478
b70fe083694d
moved values command from core to predicate compile
bulwahn
parents:
33475
diff
changeset
|
273 |
in |
36960
01594f816e3a
prefer structure Keyword, Parse, Parse_Spec, Outer_Syntax;
wenzelm
parents:
36254
diff
changeset
|
274 |
Scan.optional |
46949 | 275 |
(@{keyword "["} |-- (expected_values -- stats) -- scan_compilation --| @{keyword "]"}) |
36027
29a15da9c63d
added statistics to values command for random generation
bulwahn
parents:
36023
diff
changeset
|
276 |
((NONE, false), (Pred, [])) |
33478
b70fe083694d
moved values command from core to predicate compile
bulwahn
parents:
33475
diff
changeset
|
277 |
end |
b70fe083694d
moved values command from core to predicate compile
bulwahn
parents:
33475
diff
changeset
|
278 |
|
55437 | 279 |
|
33478
b70fe083694d
moved values command from core to predicate compile
bulwahn
parents:
33475
diff
changeset
|
280 |
(* code_pred command and values command *) |
b70fe083694d
moved values command from core to predicate compile
bulwahn
parents:
33475
diff
changeset
|
281 |
|
46961
5c6955f487e5
outer syntax command definitions based on formal command_spec derived from theory header declarations;
wenzelm
parents:
46949
diff
changeset
|
282 |
val _ = |
59936
b8ffc3dc9e24
@{command_spec} is superseded by @{command_keyword};
wenzelm
parents:
59205
diff
changeset
|
283 |
Outer_Syntax.local_theory_to_proof @{command_keyword code_pred} |
46961
5c6955f487e5
outer syntax command definitions based on formal command_spec derived from theory header declarations;
wenzelm
parents:
46949
diff
changeset
|
284 |
"prove equations for predicate specified by intro/elim rules" |
52801 | 285 |
(opt_expected_modes -- opt_modes -- scan_options -- Parse.term >> code_pred_cmd) |
33478
b70fe083694d
moved values command from core to predicate compile
bulwahn
parents:
33475
diff
changeset
|
286 |
|
46961
5c6955f487e5
outer syntax command definitions based on formal command_spec derived from theory header declarations;
wenzelm
parents:
46949
diff
changeset
|
287 |
val _ = |
59936
b8ffc3dc9e24
@{command_spec} is superseded by @{command_keyword};
wenzelm
parents:
59205
diff
changeset
|
288 |
Outer_Syntax.command @{command_keyword values} |
46961
5c6955f487e5
outer syntax command definitions based on formal command_spec derived from theory header declarations;
wenzelm
parents:
46949
diff
changeset
|
289 |
"enumerate and print comprehensions" |
5c6955f487e5
outer syntax command definitions based on formal command_spec derived from theory header declarations;
wenzelm
parents:
46949
diff
changeset
|
290 |
(opt_print_modes -- opt_param_modes -- value_options -- Scan.optional Parse.nat ~1 -- Parse.term |
5c6955f487e5
outer syntax command definitions based on formal command_spec derived from theory header declarations;
wenzelm
parents:
46949
diff
changeset
|
291 |
>> (fn ((((print_modes, param_modes), options), k), t) => Toplevel.keep |
5c6955f487e5
outer syntax command definitions based on formal command_spec derived from theory header declarations;
wenzelm
parents:
46949
diff
changeset
|
292 |
(Predicate_Compile_Core.values_cmd print_modes param_modes options k t))) |
32668
b2de45007537
added first prototype of the extended predicate compiler
bulwahn
parents:
diff
changeset
|
293 |
|
b2de45007537
added first prototype of the extended predicate compiler
bulwahn
parents:
diff
changeset
|
294 |
end |