pure Timing.timing, without any exception handling;
authorwenzelm
Sun, 20 Mar 2011 21:44:38 +0100
changeset 42013 1694cc477045
parent 42012 2c3fe3cbebae
child 42014 75417ef605ba
pure Timing.timing, without any exception handling; clarified cond_timeit: propagate interrupt without side-effect;
src/Pure/General/timing.ML
--- a/src/Pure/General/timing.ML	Sun Mar 20 21:28:11 2011 +0100
+++ b/src/Pure/General/timing.ML	Sun Mar 20 21:44:38 2011 +0100
@@ -19,6 +19,7 @@
   type start
   val start: unit -> start
   val result: start -> timing
+  val timing: ('a -> 'b) -> 'a -> timing * 'b
   val message: timing -> string
 end
 
@@ -57,6 +58,12 @@
 
 end;
 
+fun timing f x =
+  let
+    val start = start ();
+    val y = f x;
+  in (result start, y) end;
+
 
 (* timing messages *)
 
@@ -68,11 +75,12 @@
 fun cond_timeit enabled msg e =
   if enabled then
     let
-      val timing_start = start ();
-      val res = Exn.capture e ();
-      val end_msg = message (result timing_start);
-      val _ = warning (if msg = "" then end_msg else msg ^ "\n" ^ end_msg);
-    in Exn.release res end
+      val (timing, result) = timing (Exn.capture e) ();
+      val end_msg = message timing;
+      val _ =
+        if Exn.is_interrupt_exn result then ()
+        else warning (if msg = "" then end_msg else msg ^ "\n" ^ end_msg);
+    in Exn.release result end
   else e ();
 
 fun timeit e = cond_timeit true "" e;