eval_wrapper: non-critical version via unique Isabelle structure, proper forget_structure;
authorwenzelm
Fri, 28 Mar 2008 22:39:45 +0100
changeset 26473 2266e5fd7b63
parent 26472 9afdd61cf528
child 26474 94735cff132c
eval_wrapper: non-critical version via unique Isabelle structure, proper forget_structure;
src/Pure/ML/ml_context.ML
--- a/src/Pure/ML/ml_context.ML	Fri Mar 28 22:39:43 2008 +0100
+++ b/src/Pure/ML/ml_context.ML	Fri Mar 28 22:39:45 2008 +0100
@@ -32,7 +32,7 @@
     (Context.generic * Args.T list -> (string * string) * (Context.generic * Args.T list)) -> unit
   val proj_value_antiq: string -> (Context.generic * Args.T list ->
       (string * string * string) * (Context.generic * Args.T list)) -> unit
-  val eval_antiquotes_fn: (string * Position.T -> string * string) ref  (* FIXME tmp *)
+  val eval_antiquotes_fn: (string -> string * Position.T -> string * string) ref  (* FIXME tmp *)
   val trace: bool ref
   val eval: bool -> Position.T -> string -> unit
   val eval_file: Path.T -> unit
@@ -150,16 +150,14 @@
 
 local
 
-val isabelle_struct = enclose "structure Isabelle =\nstruct\n" "end;";
-val isabelle_struct0 = isabelle_struct "";
-
-fun eval_antiquotes txt_pos =
+fun eval_antiquotes struct_name txt_pos =
   let
+    val lex = ! global_lexicon;
     val ants = Antiquote.scan_antiquotes txt_pos;
 
     fun expand (Antiquote.Text s) names = (("", Symbol.escape s), names)
       | expand (Antiquote.Antiq x) names =
-          (case command (Antiquote.scan_arguments (! global_lexicon) antiq x) of
+          (case command (Antiquote.scan_arguments lex antiq x) of
             Inline s => (("", s), names)
           | ProjValue (a, s, f) =>
               let
@@ -167,14 +165,14 @@
                 val ([b], names') = Name.variants [a'] names;
                 val binding = "val " ^ b ^ " = " ^ s ^ ";\n";
                 val value =
-                  if f = "" then "Isabelle." ^ b
-                  else "(" ^ f ^ " Isabelle." ^ b ^ ")";
+                  if f = "" then struct_name ^ "." ^ b
+                  else "(" ^ f ^ " " ^ struct_name ^ "." ^ b ^ ")";
               in ((binding, value), names') end);
 
     val (decls, body) =
-      NAMED_CRITICAL "ML" (fn () => fold_map expand ants ML_Syntax.reserved)
+      fold_map expand ants ML_Syntax.reserved
       |> #1 |> split_list |> pairself implode;
-  in (isabelle_struct decls, body) end;
+  in ("structure " ^ struct_name ^ " =\nstruct\n" ^ decls ^ "end;", body) end;
 
 in
 
@@ -184,15 +182,17 @@
 
 fun eval_wrapper pr verbose pos txt =
   let
-    val (txt1, txt2) = ! eval_antiquotes_fn (txt, pos);  (* FIXME tmp hook *)
+    val struct_name =
+      if Multithreading.available then "Isabelle" ^ serial_string ()
+      else "Isabelle";
+    val (txt1, txt2) = ! eval_antiquotes_fn struct_name (txt, pos);  (* FIXME tmp hook *)
     val _ = if ! trace then tracing (cat_lines [txt1, txt2]) else ();
     fun eval p =
       use_text (the_default 1 (Position.line_of p), the_default "ML" (Position.file_of p)) pr;
   in
-    NAMED_CRITICAL "ML" (fn () =>
-     (eval Position.none false txt1;
-      eval pos verbose txt2;
-      eval Position.none false isabelle_struct0))
+    eval Position.none false txt1;
+    eval pos verbose txt2;
+    forget_structure struct_name
   end;
 
 end;
@@ -266,8 +266,7 @@
   (context -- Scan.lift Args.name --
     Scan.optional (Scan.lift (Args.$$$ "(") |-- Args.enum1 "," Args.typ --| Scan.lift (Args.$$$ ")")) []
     >> (fn ((ctxt, c), Ts) =>
-      let
-        val (c, _) = Term.dest_Const (ProofContext.read_const_proper ctxt c);
+      let val (c, _) = Term.dest_Const (ProofContext.read_const_proper ctxt c)
       in ML_Syntax.atomic (ML_Syntax.print_term (ProofContext.mk_const ctxt (c, Ts))) end));
 
 in val _ = () end;