| author | wenzelm | 
| Tue, 03 Aug 2010 22:28:43 +0200 | |
| changeset 38142 | c202426474c3 | 
| parent 36176 | 3fe7e97ccca8 | 
| child 38348 | cf7b2121ad9d | 
| permissions | -rw-r--r-- | 
| 32657 | 1 | (* Title: HOL/Code_Evaluation.thy | 
| 28228 | 2 | Author: Florian Haftmann, TU Muenchen | 
| 3 | *) | |
| 4 | ||
| 5 | header {* Term evaluation using the generic code generator *}
 | |
| 6 | ||
| 32657 | 7 | theory Code_Evaluation | 
| 31205 
98370b26c2ce
String.literal replaces message_string, code_numeral replaces (code_)index
 haftmann parents: 
31203diff
changeset | 8 | imports Plain Typerep Code_Numeral | 
| 28228 | 9 | begin | 
| 10 | ||
| 11 | subsection {* Term representation *}
 | |
| 12 | ||
| 13 | subsubsection {* Terms and class @{text term_of} *}
 | |
| 14 | ||
| 15 | datatype "term" = dummy_term | |
| 16 | ||
| 31205 
98370b26c2ce
String.literal replaces message_string, code_numeral replaces (code_)index
 haftmann parents: 
31203diff
changeset | 17 | definition Const :: "String.literal \<Rightarrow> typerep \<Rightarrow> term" where | 
| 28228 | 18 | "Const _ _ = dummy_term" | 
| 19 | ||
| 28661 | 20 | definition App :: "term \<Rightarrow> term \<Rightarrow> term" where | 
| 28228 | 21 | "App _ _ = dummy_term" | 
| 22 | ||
| 23 | code_datatype Const App | |
| 24 | ||
| 28335 | 25 | class term_of = typerep + | 
| 31031 | 26 | fixes term_of :: "'a \<Rightarrow> term" | 
| 28228 | 27 | |
| 28 | lemma term_of_anything: "term_of x \<equiv> t" | |
| 29 | by (rule eq_reflection) (cases "term_of x", cases t, simp) | |
| 30 | ||
| 31191 | 31 | definition valapp :: "('a \<Rightarrow> 'b) \<times> (unit \<Rightarrow> term)
 | 
| 31178 | 32 | \<Rightarrow> 'a \<times> (unit \<Rightarrow> term) \<Rightarrow> 'b \<times> (unit \<Rightarrow> term)" where | 
| 31191 | 33 | "valapp f x = (fst f (fst x), \<lambda>u. App (snd f ()) (snd x ()))" | 
| 31178 | 34 | |
| 32069 
6d28bbd33e2c
prefer code_inline over code_unfold; use code_unfold_post where appropriate
 haftmann parents: 
31998diff
changeset | 35 | lemma valapp_code [code, code_unfold]: | 
| 31191 | 36 | "valapp (f, tf) (x, tx) = (f x, \<lambda>u. App (tf ()) (tx ()))" | 
| 37 | by (simp only: valapp_def fst_conv snd_conv) | |
| 31178 | 38 | |
| 28228 | 39 | |
| 40 | subsubsection {* @{text term_of} instances *}
 | |
| 41 | ||
| 32344 | 42 | instantiation "fun" :: (typerep, typerep) term_of | 
| 43 | begin | |
| 44 | ||
| 45 | definition | |
| 46 | "term_of (f \<Colon> 'a \<Rightarrow> 'b) = Const (STR ''dummy_pattern'') (Typerep.Typerep (STR ''fun'') | |
| 47 |      [Typerep.typerep TYPE('a), Typerep.typerep TYPE('b)])"
 | |
| 48 | ||
| 49 | instance .. | |
| 50 | ||
| 51 | end | |
| 52 | ||
| 28228 | 53 | setup {*
 | 
| 54 | let | |
| 31139 | 55 | fun add_term_of tyco raw_vs thy = | 
| 28228 | 56 | let | 
| 31139 | 57 |       val vs = map (fn (v, _) => (v, @{sort typerep})) raw_vs;
 | 
| 58 | val ty = Type (tyco, map TFree vs); | |
| 28228 | 59 |       val lhs = Const (@{const_name term_of}, ty --> @{typ term})
 | 
| 60 |         $ Free ("x", ty);
 | |
| 61 |       val rhs = @{term "undefined \<Colon> term"};
 | |
| 62 | val eq = HOLogic.mk_Trueprop (HOLogic.mk_eq (lhs, rhs)); | |
| 28243 | 63 | fun triv_name_of t = (fst o dest_Free o fst o strip_comb o fst | 
| 64 | o HOLogic.dest_eq o HOLogic.dest_Trueprop) t ^ "_triv"; | |
| 28228 | 65 | in | 
| 66 | thy | |
| 33553 | 67 |       |> Theory_Target.instantiation ([tyco], vs, @{sort term_of})
 | 
| 28228 | 68 | |> `(fn lthy => Syntax.check_term lthy eq) | 
| 28965 | 69 | |-> (fn eq => Specification.definition (NONE, ((Binding.name (triv_name_of eq), []), eq))) | 
| 28228 | 70 | |> snd | 
| 31139 | 71 | |> Class.prove_instantiation_exit (K (Class.intro_classes_tac [])) | 
| 28228 | 72 | end; | 
| 31139 | 73 | fun ensure_term_of (tyco, (raw_vs, _)) thy = | 
| 74 | let | |
| 75 |       val need_inst = not (can (Sorts.mg_domain (Sign.classes_of thy) tyco) @{sort term_of})
 | |
| 76 |         andalso can (Sorts.mg_domain (Sign.classes_of thy) tyco) @{sort typerep};
 | |
| 31205 
98370b26c2ce
String.literal replaces message_string, code_numeral replaces (code_)index
 haftmann parents: 
31203diff
changeset | 77 | in if need_inst then add_term_of tyco raw_vs thy else thy end; | 
| 28228 | 78 | in | 
| 35299 
4f4d5bf4ea08
proper distinction of code datatypes and abstypes
 haftmann parents: 
34028diff
changeset | 79 | Code.datatype_interpretation ensure_term_of | 
| 
4f4d5bf4ea08
proper distinction of code datatypes and abstypes
 haftmann parents: 
34028diff
changeset | 80 | #> Code.abstype_interpretation ensure_term_of | 
| 28228 | 81 | end | 
| 82 | *} | |
| 83 | ||
| 84 | setup {*
 | |
| 85 | let | |
| 31139 | 86 | fun mk_term_of_eq thy ty vs tyco (c, tys) = | 
| 28228 | 87 | let | 
| 88 | val t = list_comb (Const (c, tys ---> ty), | |
| 89 | map Free (Name.names Name.context "a" tys)); | |
| 35845 
e5980f0ad025
renamed varify/unvarify operations to varify_global/unvarify_global to emphasize that these only work in a global situation;
 wenzelm parents: 
35366diff
changeset | 90 | val (arg, rhs) = | 
| 
e5980f0ad025
renamed varify/unvarify operations to varify_global/unvarify_global to emphasize that these only work in a global situation;
 wenzelm parents: 
35366diff
changeset | 91 | pairself (Thm.cterm_of thy o map_types Logic.unvarifyT_global o Logic.varify_global) | 
| 
e5980f0ad025
renamed varify/unvarify operations to varify_global/unvarify_global to emphasize that these only work in a global situation;
 wenzelm parents: 
35366diff
changeset | 92 | (t, (map_aterms (fn t as Free (v, ty) => HOLogic.mk_term_of ty t | t => t) o HOLogic.reflect_term) t) | 
| 31139 | 93 | val cty = Thm.ctyp_of thy ty; | 
| 94 | in | |
| 95 |       @{thm term_of_anything}
 | |
| 96 | |> Drule.instantiate' [SOME cty] [SOME arg, SOME rhs] | |
| 35845 
e5980f0ad025
renamed varify/unvarify operations to varify_global/unvarify_global to emphasize that these only work in a global situation;
 wenzelm parents: 
35366diff
changeset | 97 | |> Thm.varifyT_global | 
| 28228 | 98 | end; | 
| 31139 | 99 | fun add_term_of_code tyco raw_vs raw_cs thy = | 
| 28228 | 100 | let | 
| 31746 
75fe3304015c
code equation observes default sort constraints for types
 haftmann parents: 
31594diff
changeset | 101 | val algebra = Sign.classes_of thy; | 
| 
75fe3304015c
code equation observes default sort constraints for types
 haftmann parents: 
31594diff
changeset | 102 | val vs = map (fn (v, sort) => | 
| 
75fe3304015c
code equation observes default sort constraints for types
 haftmann parents: 
31594diff
changeset | 103 |         (v, curry (Sorts.inter_sort algebra) @{sort typerep} sort)) raw_vs;
 | 
| 31139 | 104 | val ty = Type (tyco, map TFree vs); | 
| 105 | val cs = (map o apsnd o map o map_atyps) | |
| 106 | (fn TFree (v, _) => TFree (v, (the o AList.lookup (op =) vs) v)) raw_cs; | |
| 107 |       val const = AxClass.param_of_inst thy (@{const_name term_of}, tyco);
 | |
| 108 | val eqs = map (mk_term_of_eq thy ty vs tyco) cs; | |
| 109 | in | |
| 110 | thy | |
| 111 | |> Code.del_eqns const | |
| 112 | |> fold Code.add_eqn eqs | |
| 113 | end; | |
| 114 | fun ensure_term_of_code (tyco, (raw_vs, cs)) thy = | |
| 115 | let | |
| 116 |       val has_inst = can (Sorts.mg_domain (Sign.classes_of thy) tyco) @{sort term_of};
 | |
| 31205 
98370b26c2ce
String.literal replaces message_string, code_numeral replaces (code_)index
 haftmann parents: 
31203diff
changeset | 117 | in if has_inst then add_term_of_code tyco raw_vs cs thy else thy end; | 
| 28228 | 118 | in | 
| 35299 
4f4d5bf4ea08
proper distinction of code datatypes and abstypes
 haftmann parents: 
34028diff
changeset | 119 | Code.datatype_interpretation ensure_term_of_code | 
| 28228 | 120 | end | 
| 121 | *} | |
| 122 | ||
| 35366 | 123 | setup {*
 | 
| 124 | let | |
| 125 | fun mk_term_of_eq thy ty vs tyco abs ty_rep proj = | |
| 126 | let | |
| 127 |       val arg = Var (("x", 0), ty);
 | |
| 128 |       val rhs = Abs ("y", @{typ term}, HOLogic.reflect_term (Const (abs, ty_rep --> ty) $ Bound 0)) $
 | |
| 129 | (HOLogic.mk_term_of ty_rep (Const (proj, ty --> ty_rep) $ arg)) | |
| 130 | |> Thm.cterm_of thy; | |
| 131 | val cty = Thm.ctyp_of thy ty; | |
| 132 | in | |
| 133 |       @{thm term_of_anything}
 | |
| 134 | |> Drule.instantiate' [SOME cty] [SOME (Thm.cterm_of thy arg), SOME rhs] | |
| 35845 
e5980f0ad025
renamed varify/unvarify operations to varify_global/unvarify_global to emphasize that these only work in a global situation;
 wenzelm parents: 
35366diff
changeset | 135 | |> Thm.varifyT_global | 
| 35366 | 136 | end; | 
| 137 | fun add_term_of_code tyco raw_vs abs raw_ty_rep proj thy = | |
| 138 | let | |
| 139 | val algebra = Sign.classes_of thy; | |
| 140 | val vs = map (fn (v, sort) => | |
| 141 |         (v, curry (Sorts.inter_sort algebra) @{sort typerep} sort)) raw_vs;
 | |
| 142 | val ty = Type (tyco, map TFree vs); | |
| 143 | val ty_rep = map_atyps | |
| 144 | (fn TFree (v, _) => TFree (v, (the o AList.lookup (op =) vs) v)) raw_ty_rep; | |
| 145 |       val const = AxClass.param_of_inst thy (@{const_name term_of}, tyco);
 | |
| 146 | val eq = mk_term_of_eq thy ty vs tyco abs ty_rep proj; | |
| 147 | in | |
| 148 | thy | |
| 149 | |> Code.del_eqns const | |
| 150 | |> Code.add_eqn eq | |
| 151 | end; | |
| 152 | fun ensure_term_of_code (tyco, (raw_vs, ((abs, ty), (proj, _)))) thy = | |
| 153 | let | |
| 154 |       val has_inst = can (Sorts.mg_domain (Sign.classes_of thy) tyco) @{sort term_of};
 | |
| 155 | in if has_inst then add_term_of_code tyco raw_vs abs ty proj thy else thy end; | |
| 156 | in | |
| 157 | Code.abstype_interpretation ensure_term_of_code | |
| 158 | end | |
| 159 | *} | |
| 160 | ||
| 28228 | 161 | |
| 162 | subsubsection {* Code generator setup *}
 | |
| 163 | ||
| 28562 | 164 | lemmas [code del] = term.recs term.cases term.size | 
| 165 | lemma [code, code del]: "eq_class.eq (t1\<Colon>term) t2 \<longleftrightarrow> eq_class.eq t1 t2" .. | |
| 28228 | 166 | |
| 28562 | 167 | lemma [code, code del]: "(term_of \<Colon> typerep \<Rightarrow> term) = term_of" .. | 
| 168 | lemma [code, code del]: "(term_of \<Colon> term \<Rightarrow> term) = term_of" .. | |
| 31205 
98370b26c2ce
String.literal replaces message_string, code_numeral replaces (code_)index
 haftmann parents: 
31203diff
changeset | 169 | lemma [code, code del]: "(term_of \<Colon> String.literal \<Rightarrow> term) = term_of" .. | 
| 30427 | 170 | lemma [code, code del]: | 
| 32657 | 171 |   "(Code_Evaluation.term_of \<Colon> 'a::{type, term_of} Predicate.pred \<Rightarrow> Code_Evaluation.term) = Code_Evaluation.term_of" ..
 | 
| 30427 | 172 | lemma [code, code del]: | 
| 32657 | 173 |   "(Code_Evaluation.term_of \<Colon> 'a::{type, term_of} Predicate.seq \<Rightarrow> Code_Evaluation.term) = Code_Evaluation.term_of" ..
 | 
| 28228 | 174 | |
| 32657 | 175 | lemma term_of_char [unfolded typerep_fun_def typerep_char_def typerep_nibble_def, code]: "Code_Evaluation.term_of c = | 
| 28243 | 176 | (let (n, m) = nibble_pair_of_char c | 
| 32657 | 177 | in Code_Evaluation.App (Code_Evaluation.App (Code_Evaluation.Const (STR ''String.char.Char'') (TYPEREP(nibble \<Rightarrow> nibble \<Rightarrow> char))) | 
| 178 | (Code_Evaluation.term_of n)) (Code_Evaluation.term_of m))" | |
| 28243 | 179 | by (subst term_of_anything) rule | 
| 180 | ||
| 28228 | 181 | code_type "term" | 
| 31031 | 182 | (Eval "Term.term") | 
| 28228 | 183 | |
| 184 | code_const Const and App | |
| 31594 | 185 | (Eval "Term.Const/ ((_), (_))" and "Term.$/ ((_), (_))") | 
| 28228 | 186 | |
| 31205 
98370b26c2ce
String.literal replaces message_string, code_numeral replaces (code_)index
 haftmann parents: 
31203diff
changeset | 187 | code_const "term_of \<Colon> String.literal \<Rightarrow> term" | 
| 33632 
6ea8a4cce9e7
repaired broken code_const for term_of [String.literal]
 haftmann parents: 
33553diff
changeset | 188 | (Eval "HOLogic.mk'_literal") | 
| 31048 
ac146fc38b51
refined HOL string theories and corresponding ML fragments
 haftmann parents: 
31031diff
changeset | 189 | |
| 
ac146fc38b51
refined HOL string theories and corresponding ML fragments
 haftmann parents: 
31031diff
changeset | 190 | code_reserved Eval HOLogic | 
| 28228 | 191 | |
| 192 | ||
| 31178 | 193 | subsubsection {* Syntax *}
 | 
| 194 | ||
| 31191 | 195 | definition termify :: "'a \<Rightarrow> term" where | 
| 196 | [code del]: "termify x = dummy_term" | |
| 197 | ||
| 198 | abbreviation valtermify :: "'a \<Rightarrow> 'a \<times> (unit \<Rightarrow> term)" where | |
| 199 | "valtermify x \<equiv> (x, \<lambda>u. termify x)" | |
| 31178 | 200 | |
| 201 | setup {*
 | |
| 202 | let | |
| 203 | fun map_default f xs = | |
| 204 | let val ys = map f xs | |
| 205 | in if exists is_some ys | |
| 206 | then SOME (map2 the_default xs ys) | |
| 207 | else NONE | |
| 208 | end; | |
| 209 |   fun subst_termify_app (Const (@{const_name termify}, T), [t]) =
 | |
| 210 | if not (Term.has_abs t) | |
| 211 | then if fold_aterms (fn Const _ => I | _ => K false) t true | |
| 31191 | 212 | then SOME (HOLogic.reflect_term t) | 
| 31178 | 213 | else error "Cannot termify expression containing variables" | 
| 214 | else error "Cannot termify expression containing abstraction" | |
| 215 | | subst_termify_app (t, ts) = case map_default subst_termify ts | |
| 216 | of SOME ts' => SOME (list_comb (t, ts')) | |
| 217 | | NONE => NONE | |
| 218 | and subst_termify (Abs (v, T, t)) = (case subst_termify t | |
| 219 | of SOME t' => SOME (Abs (v, T, t')) | |
| 220 | | NONE => NONE) | |
| 221 | | subst_termify t = subst_termify_app (strip_comb t) | |
| 222 | fun check_termify ts ctxt = map_default subst_termify ts | |
| 223 | |> Option.map (rpair ctxt) | |
| 224 | in | |
| 225 | Context.theory_map (Syntax.add_term_check 0 "termify" check_termify) | |
| 226 | end; | |
| 227 | *} | |
| 228 | ||
| 229 | locale term_syntax | |
| 230 | begin | |
| 231 | ||
| 31191 | 232 | notation App (infixl "<\<cdot>>" 70) | 
| 233 |   and valapp (infixl "{\<cdot>}" 70)
 | |
| 31178 | 234 | |
| 235 | end | |
| 236 | ||
| 237 | interpretation term_syntax . | |
| 238 | ||
| 31191 | 239 | no_notation App (infixl "<\<cdot>>" 70) | 
| 240 |   and valapp (infixl "{\<cdot>}" 70)
 | |
| 241 | ||
| 242 | ||
| 243 | subsection {* Numeric types *}
 | |
| 244 | ||
| 245 | definition term_of_num :: "'a\<Colon>{semiring_div} \<Rightarrow> 'a\<Colon>{semiring_div} \<Rightarrow> term" where
 | |
| 246 | "term_of_num two = (\<lambda>_. dummy_term)" | |
| 247 | ||
| 248 | lemma (in term_syntax) term_of_num_code [code]: | |
| 249 | "term_of_num two k = (if k = 0 then termify Int.Pls | |
| 250 | else (if k mod two = 0 | |
| 251 | then termify Int.Bit0 <\<cdot>> term_of_num two (k div two) | |
| 252 | else termify Int.Bit1 <\<cdot>> term_of_num two (k div two)))" | |
| 253 | by (auto simp add: term_of_anything Const_def App_def term_of_num_def Let_def) | |
| 254 | ||
| 255 | lemma (in term_syntax) term_of_nat_code [code]: | |
| 256 | "term_of (n::nat) = termify (number_of :: int \<Rightarrow> nat) <\<cdot>> term_of_num (2::nat) n" | |
| 257 | by (simp only: term_of_anything) | |
| 258 | ||
| 259 | lemma (in term_syntax) term_of_int_code [code]: | |
| 260 | "term_of (k::int) = (if k = 0 then termify (0 :: int) | |
| 261 | else if k > 0 then termify (number_of :: int \<Rightarrow> int) <\<cdot>> term_of_num (2::int) k | |
| 262 | else termify (uminus :: int \<Rightarrow> int) <\<cdot>> (termify (number_of :: int \<Rightarrow> int) <\<cdot>> term_of_num (2::int) (- k)))" | |
| 263 | by (simp only: term_of_anything) | |
| 264 | ||
| 31205 
98370b26c2ce
String.literal replaces message_string, code_numeral replaces (code_)index
 haftmann parents: 
31203diff
changeset | 265 | lemma (in term_syntax) term_of_code_numeral_code [code]: | 
| 
98370b26c2ce
String.literal replaces message_string, code_numeral replaces (code_)index
 haftmann parents: 
31203diff
changeset | 266 | "term_of (k::code_numeral) = termify (number_of :: int \<Rightarrow> code_numeral) <\<cdot>> term_of_num (2::code_numeral) k" | 
| 31203 
5c8fb4fd67e0
moved Code_Index, Random and Quickcheck before Main
 haftmann parents: 
31191diff
changeset | 267 | by (simp only: term_of_anything) | 
| 31191 | 268 | |
| 269 | subsection {* Obfuscate *}
 | |
| 31178 | 270 | |
| 271 | print_translation {*
 | |
| 272 | let | |
| 273 |   val term = Const ("<TERM>", dummyT);
 | |
| 274 | fun tr1' [_, _] = term; | |
| 275 | fun tr2' [] = term; | |
| 276 | in | |
| 277 |   [(@{const_syntax Const}, tr1'),
 | |
| 278 |     (@{const_syntax App}, tr1'),
 | |
| 279 |     (@{const_syntax dummy_term}, tr2')]
 | |
| 280 | end | |
| 281 | *} | |
| 282 | ||
| 36176 
3fe7e97ccca8
replaced generic 'hide' command by more conventional 'hide_class', 'hide_type', 'hide_const', 'hide_fact' -- frees some popular keywords;
 wenzelm parents: 
35845diff
changeset | 283 | hide_const dummy_term App valapp | 
| 
3fe7e97ccca8
replaced generic 'hide' command by more conventional 'hide_class', 'hide_type', 'hide_const', 'hide_fact' -- frees some popular keywords;
 wenzelm parents: 
35845diff
changeset | 284 | hide_const (open) Const termify valtermify term_of term_of_num | 
| 31178 | 285 | |
| 33473 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 286 | subsection {* Tracing of generated and evaluated code *}
 | 
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 287 | |
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 288 | definition tracing :: "String.literal => 'a => 'a" | 
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 289 | where | 
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 290 | [code del]: "tracing s x = x" | 
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 291 | |
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 292 | ML {*
 | 
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 293 | structure Code_Evaluation = | 
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 294 | struct | 
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 295 | |
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 296 | fun tracing s x = (Output.tracing s; x) | 
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 297 | |
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 298 | end | 
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 299 | *} | 
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 300 | |
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 301 | code_const "tracing :: String.literal => 'a => 'a" | 
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 302 | (Eval "Code'_Evaluation.tracing") | 
| 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 303 | |
| 36176 
3fe7e97ccca8
replaced generic 'hide' command by more conventional 'hide_class', 'hide_type', 'hide_const', 'hide_fact' -- frees some popular keywords;
 wenzelm parents: 
35845diff
changeset | 304 | hide_const (open) tracing | 
| 33473 
3b275a0bf18c
adding tracing function for evaluated code; annotated compilation in the predicate compiler
 bulwahn parents: 
32740diff
changeset | 305 | code_reserved Eval Code_Evaluation | 
| 31178 | 306 | |
| 28228 | 307 | subsection {* Evaluation setup *}
 | 
| 308 | ||
| 309 | ML {*
 | |
| 310 | signature EVAL = | |
| 311 | sig | |
| 32740 | 312 | val eval_ref: (unit -> term) option Unsynchronized.ref | 
| 28228 | 313 | val eval_term: theory -> term -> term | 
| 314 | end; | |
| 315 | ||
| 316 | structure Eval : EVAL = | |
| 317 | struct | |
| 318 | ||
| 32740 | 319 | val eval_ref = Unsynchronized.ref (NONE : (unit -> term) option); | 
| 28228 | 320 | |
| 321 | fun eval_term thy t = | |
| 34028 
1e6206763036
split off evaluation mechanisms in separte module Code_Eval
 haftmann parents: 
33632diff
changeset | 322 |   Code_Eval.eval NONE ("Eval.eval_ref", eval_ref) I thy (HOLogic.mk_term_of (fastype_of t) t) [];
 | 
| 28228 | 323 | |
| 324 | end; | |
| 325 | *} | |
| 326 | ||
| 327 | setup {*
 | |
| 328 |   Value.add_evaluator ("code", Eval.eval_term o ProofContext.theory_of)
 | |
| 329 | *} | |
| 330 | ||
| 331 | end |