excursion/unit_result: no print for forked end, finish into global theory, pick resul from presentation context;
authorwenzelm
Wed, 01 Oct 2008 22:33:28 +0200
changeset 28453 06702e7acd1d
parent 28452 a72670460833
child 28454 c63168db774c
excursion/unit_result: no print for forked end, finish into global theory, pick resul from presentation context; tuned;
src/Pure/Isar/toplevel.ML
--- a/src/Pure/Isar/toplevel.ML	Wed Oct 01 22:33:24 2008 +0200
+++ b/src/Pure/Isar/toplevel.ML	Wed Oct 01 22:33:28 2008 +0200
@@ -455,8 +455,10 @@
 val reset_trans = map_transition (fn (name, pos, int_only, print, no_timing, _) =>
   (name, pos, int_only, print, no_timing, []));
 
-val print = map_transition (fn (name, pos, int_only, _, no_timing, trans) =>
-  (name, pos, int_only, true, no_timing, trans));
+fun set_print print = map_transition (fn (name, pos, int_only, _, no_timing, trans) =>
+  (name, pos, int_only, print, no_timing, trans));
+
+val print = set_print true;
 
 
 (* basic transitions *)
@@ -696,25 +698,26 @@
 
 fun unit_result immediate (tr, proof_trs) st =
   let val st' = command tr st in
-    if not immediate andalso not (null proof_trs) andalso
-      can proof_of st' andalso Proof.can_defer (proof_of st')
+    if immediate orelse null proof_trs orelse
+      not (can proof_of st') orelse Proof.is_relevant (proof_of st')
     then
+      let val (states, st'') = fold_map command_result proof_trs st'
+      in (fn () => (tr, st') :: (proof_trs ~~ states), st'') end
+    else
       let
         val (body_trs, end_tr) = split_last proof_trs;
         val body_states = ref ([]: state list);
+        val finish = Context.Theory o ProofContext.theory_of;
         fun make_result prf =
-          let val (states, result_state) =
+          let val (states, State (result_node, _)) =
             (case st' of State (SOME (Proof (_, (_, orig_gthy)), exit), prev)
-              => State (SOME (Proof (ProofNode.init prf, (Context.Proof, orig_gthy)), exit), prev))
-            |> fold_map command_result body_trs ||> command end_tr
-          in body_states := states; context_of result_state end;
-        val proof_future =
-          end_tr |> reset_trans |> end_proof (K (Proof.future_proof make_result));
-        val st'' = command proof_future st';
+              => State (SOME (Proof (ProofNode.init prf, (finish, orig_gthy)), exit), prev))
+            |> fold_map command_result body_trs
+            ||> command (end_tr |> set_print false)
+          in body_states := states; presentation_context (Option.map #1 result_node) NONE end;
+        val st'' = st'
+          |> command (end_tr |> reset_trans |> end_proof (K (Proof.future_proof make_result)));
       in (fn () => (tr, st') :: (body_trs ~~ ! body_states) @ [(end_tr, st'')], st'') end
-    else
-      let val (states, st'') = fold_map command_result proof_trs st'
-      in (fn () => (tr, st') :: (proof_trs ~~ states), st'') end
   end;
 
 fun excursion input =