eval_term: moved actual evaluation out of CRITICAL section;
authorwenzelm
Fri, 12 Oct 2007 18:09:12 +0200
changeset 25009 61946780de00
parent 25008 38f4ecb71e8c
child 25010 8bc74ba1423d
eval_term: moved actual evaluation out of CRITICAL section;
src/Pure/codegen.ML
--- a/src/Pure/codegen.ML	Fri Oct 12 15:46:29 2007 +0200
+++ b/src/Pure/codegen.ML	Fri Oct 12 18:09:12 2007 +0200
@@ -1013,26 +1013,28 @@
 
 val eval_result = ref (fn () => Bound 0);
 
-fun eval_term thy = PrintMode.setmp [] (fn t =>
-  let
-    val _ = (null (term_tvars t) andalso null (term_tfrees t)) orelse
-      error "Term to be evaluated contains type variables";
-    val _ = (null (term_vars t) andalso null (term_frees t)) orelse
-      error "Term to be evaluated contains variables";
-    val (code, gr) = setmp mode ["term_of"]
-      (generate_code_i thy [] "Generated")
-      [("result", Abs ("x", TFree ("'a", []), t))];
-    val s = "structure EvalTerm =\nstruct\n\n" ^
-      space_implode "\n" (map snd code) ^
-      "\nopen Generated;\n\n" ^ Pretty.string_of
-        (Pretty.block [Pretty.str "val () = Codegen.eval_result := (fn () =>",
-          Pretty.brk 1,
-          mk_app false (mk_term_of gr "Generated" false (fastype_of t))
-            [Pretty.str "(result ())"],
-          Pretty.str ");"]) ^
-      "\n\nend;\n";
-    val _ = ML_Context.use_mltext s false (SOME (Context.Theory thy))
-  in !eval_result () end);
+fun eval_term thy t =
+  let val e = PrintMode.setmp [] (fn () =>
+    let
+      val _ = (null (term_tvars t) andalso null (term_tfrees t)) orelse
+        error "Term to be evaluated contains type variables";
+      val _ = (null (term_vars t) andalso null (term_frees t)) orelse
+        error "Term to be evaluated contains variables";
+      val (code, gr) = setmp mode ["term_of"]
+        (generate_code_i thy [] "Generated")
+        [("result", Abs ("x", TFree ("'a", []), t))];
+      val s = "structure EvalTerm =\nstruct\n\n" ^
+        space_implode "\n" (map snd code) ^
+        "\nopen Generated;\n\n" ^ Pretty.string_of
+          (Pretty.block [Pretty.str "val () = Codegen.eval_result := (fn () =>",
+            Pretty.brk 1,
+            mk_app false (mk_term_of gr "Generated" false (fastype_of t))
+              [Pretty.str "(result ())"],
+            Pretty.str ");"]) ^
+        "\n\nend;\n";
+      val _ = ML_Context.use_mltext s false (SOME (Context.Theory thy))
+    in !eval_result end) ();
+  in e () end;
 
 fun print_evaluated_term s = Toplevel.keep (fn state =>
   let