]> matita.cs.unibo.it Git - helm.git/blobdiff - helm/software/components/extlib/hExtlib.ml
commented the finally function
[helm.git] / helm / software / components / extlib / hExtlib.ml
index ded11b9fea412d5e8c917bf6fb79ebf4fb89b926..57511db0e5205d7a61bee0f074f3631d88815914 100644 (file)
 
 (** PROFILING *)
 
-let profiling_enabled = ComponentsConf.profiling
+let profiling_enabled = false ;; (* ComponentsConf.profiling *)
+
+let something_profiled = ref false
 
 let _ = 
-  if profiling_enabled then
+  if !something_profiled then
     at_exit 
-      (fun _ -> prerr_endline 
-        (Printf.sprintf "!! %-39s %6s %9s %9s %9s" 
-          "function" "#calls" "total" "max" "average"))
+      (fun _ -> 
+        prerr_endline 
+         (Printf.sprintf "!! %39s ---------- --------- --------- ---------" 
+           (String.make 39 '-'));
+        prerr_endline 
+         (Printf.sprintf "!! %-39s %10s %9s %9s %9s" 
+           "function" "#calls" "total" "max" "average"))
 
 let profiling_printings = ref (fun _ -> true)
 let set_profiling_printings f = profiling_printings := f
@@ -65,10 +71,13 @@ let profile ?(enable = true) s =
    in
    at_exit
     (fun () ->
-      if !profiling_printings s && !total <> 0. then
+      if !profiling_printings s && !calls <> 0 then
+       begin
+        something_profiled := true;
         prerr_endline
-         (Printf.sprintf "!! %-39s %6d %9.4f %9.4f %9.4f" 
-         s !calls !total !max (!total /. (float_of_int !calls))));
+         (Printf.sprintf "!! %-39s %10d %9.4f %9.4f %9.4f" 
+         s !calls !total !max (!total /. (float_of_int !calls)))
+       end);
    { profile = profile }
  else
    { profile = fun f x -> f x }
@@ -356,3 +365,7 @@ let raise_localized_exception ~offset floc exn =
    { flocb with Lexing.pos_cnum = x }, { floce with Lexing.pos_cnum = y }
  in
   raise (Localized (floc, exn))
+
+let estimate_size x = 
+  4 * (String.length (Marshal.to_string x [])) / 1024
+