aboutsummaryrefslogtreecommitdiff
path: root/lib/errors.ml
diff options
context:
space:
mode:
authorletouzey2013-03-12 23:59:02 +0000
committerletouzey2013-03-12 23:59:02 +0000
commitb66d099bdda2ce1cfaeeb7938346a348ef4d40cd (patch)
tree0a05f3bb096de81ac618bb93101c8d3a60969a86 /lib/errors.ml
parent091824ae0f9bffcdee757bbd048e8a0f63cc5054 (diff)
New function Errors.noncritical for restricting try ... with ...
For the moment, are considered critical : Sys.Break, Stack_overflow, Out_of_memory Assert_failure, Match_failure, Anomaly, Timeout, Drop, Exit These exceptions should normally *not* be catched by a "try", hence the suggested code for generic "try": try ... with e when Errors.noncritical e -> ... git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@16269 85f007b7-540e-0410-9357-904b9bb8a0f7
Diffstat (limited to 'lib/errors.ml')
-rw-r--r--lib/errors.ml10
1 files changed, 10 insertions, 0 deletions
diff --git a/lib/errors.ml b/lib/errors.ml
index 92e5ac6423..27baf4314f 100644
--- a/lib/errors.ml
+++ b/lib/errors.ml
@@ -124,3 +124,13 @@ let _ = register_handler begin function
| UserError(s,pps) -> hov 0 (str "Error: " ++ where (Some s) ++ pps)
| _ -> raise Unhandled
end
+
+(** Critical exceptions shouldn't be catched and ignored by mistake
+ by inner functions during a [vernacinterp]. They should be handled
+ only at the very end of interp, to be displayed to the user. *)
+
+let noncritical = function
+ | Sys.Break | Out_of_memory | Stack_overflow
+ | Assert_failure _ | Match_failure _ | Anomaly _
+ | Timeout | Drop | Quit -> false
+ | _ -> true