debug: exception_trace;
authorwenzelm
Wed, 06 Jul 2005 20:00:41 +0200
changeset 16729 24c5c94aa967
parent 16728 c4c9d5df26ba
child 16730 ff304c52bf86
debug: exception_trace; tuned;
src/Pure/Isar/toplevel.ML
--- a/src/Pure/Isar/toplevel.ML	Wed Jul 06 20:00:40 2005 +0200
+++ b/src/Pure/Isar/toplevel.ML	Wed Jul 06 20:00:41 2005 +0200
@@ -206,37 +206,49 @@
 fun copy_node true (Theory thy) = Theory (Theory.copy thy)
   | copy_node _ node = node;
 
-fun interruptible f x =
-  let val y = ref (NONE: node History.T option);
-  in raise_interrupt (fn () => y := SOME (f x)) (); the (! y) end;
-
-val rollback = ERROR_MESSAGE "Stale theory encountered after succesful execution!";
+val stale_theory = ERROR_MESSAGE "Stale theory encountered after succesful execution!";
 
 fun return (result, NONE) = result
   | return (result, SOME exn) = raise FAILURE (result, exn);
 
+fun debug_trans f x =
+  if ! debug then
+    let val y = ref x in
+      setmp Output.transform_exceptions false
+        exception_trace (fn () => y := f x); ! y
+    end
+  else f x;
+
+fun interruptible f x =
+  let val y = ref x
+  in raise_interrupt (fn () => y := f x) (); ! y end;
+
 in
 
 fun node_trans _ _ _ (State NONE) = raise UNDEF
   | node_trans int hist f (State (SOME (node, term))) =
       let
-        fun mk_state nd = State (SOME (nd, term));
-
         val cont_node = History.map (checkpoint_node int) node;
         val back_node = History.map (copy_node int) cont_node;
+        fun state nd = State (SOME (nd, term));
+        fun normal_state nd = (state nd, NONE);
+        fun error_state nd exn = (state nd, SOME exn);
 
-        val trans = if hist then History.apply_copy (copy_node int) else History.map;
-        val (result, opt_exn) =
-          (mk_state (transform_error (interruptible (trans (f int))) cont_node), NONE)
-            handle exn => (mk_state cont_node, SOME exn);
+        val (result, err) =
+          cont_node
+          |> ((fn nd => f int nd)
+              |> (if hist then History.apply_copy (copy_node int) else History.map)
+              |> debug_trans
+              |> interruptible
+              |> transform_error)
+          |> normal_state
+          handle exn => error_state cont_node exn;
       in
-        if is_stale result then return (mk_state back_node, SOME (if_none opt_exn rollback))
-        else return (result, opt_exn)
+        if is_stale result
+        then return (error_state back_node (if_none err stale_theory))
+        else return (result, err)
       end;
 
-fun check_stale state =
-  conditional (is_stale state) (fn () => warning "Stale theory encountered!");
-
 end;
 
 
@@ -478,8 +490,6 @@
 
 in
 
-val debug = ref false;
-
 fun exn_message exn = exn_msg (! debug) exn;
 
 fun print_exn NONE = ()
@@ -503,8 +513,9 @@
     fun do_profiling f x = profile (! profiling) f x;
 
     val (result, opt_exn) =
-      (if ! profiling > 0 orelse ! timing andalso not no_timing then do_timing else I)
-        ((if ! profiling > 0 then do_profiling else I) (apply_trans int trans)) state;
+       state |> (apply_trans int trans
+        |> (if ! profiling > 0 then do_profiling else I)
+        |> (if ! profiling > 0 orelse ! timing andalso not no_timing then do_timing else I));
     val _ = conditional (int andalso not (! quiet) andalso
         exists (fn m => m mem_string print) ("" :: ! print_mode))
       (fn () => print_state false result);
@@ -580,7 +591,7 @@
     NONE => false
   | SOME (state', exn_info) =>
       (global_state := (state', exn_info);
-        check_stale state'; print_exn exn_info;
+        print_exn exn_info;
         true));
 
 fun >>> [] = ()
@@ -596,8 +607,6 @@
   | SOME NONE => ()
   | SOME (SOME (tr, src')) => if >> tr then raw_loop src' else ());
 
-
 fun loop src = ignore_interrupt raw_loop src;
 
-
 end;