aboutsummaryrefslogtreecommitdiff
path: root/lib/control.ml
diff options
context:
space:
mode:
authorEmilio Jesus Gallego Arias2019-04-04 00:09:10 +0200
committerEmilio Jesus Gallego Arias2019-04-04 00:09:10 +0200
commit2af2ea43c199177efe64678506e4fe419ea17404 (patch)
tree2c6aa80ad8a9c8f2da4c803da89b3e6742d3887f /lib/control.ml
parentf72de71c43f09554001bbe5808518171a68af335 (diff)
parentf374b79e08e135de11def93005110a833686c5f7 (diff)
Merge PR #9881: Protect some I/O routines from SIGALRM
Ack-by: SkySkimmer Reviewed-by: ejgallego Ack-by: maximedenes
Diffstat (limited to 'lib/control.ml')
-rw-r--r--lib/control.ml18
1 files changed, 18 insertions, 0 deletions
diff --git a/lib/control.ml b/lib/control.ml
index ffb3584f1e..9054507e46 100644
--- a/lib/control.ml
+++ b/lib/control.ml
@@ -89,3 +89,21 @@ let timeout_fun_ref = ref timeout_fun
let set_timeout f = timeout_fun_ref := f
let timeout n f e = !timeout_fun_ref.timeout n f e
+
+let protect_sigalrm f x =
+ let timed_out = ref false in
+ let timeout_handler _ = timed_out := true in
+ try
+ let old_handler = Sys.signal Sys.sigalrm (Sys.Signal_handle timeout_handler) in
+ try
+ let res = f x in
+ Sys.set_signal Sys.sigalrm old_handler;
+ match !timed_out, old_handler with
+ | true, Sys.Signal_handle f -> f Sys.sigalrm; res
+ | _, _ -> res
+ with e ->
+ let e = Backtrace.add_backtrace e in
+ Sys.set_signal Sys.sigalrm old_handler;
+ Exninfo.iraise e
+ with Invalid_argument _ -> (* This happens on Windows, as handling SIGALRM does not seem supported *)
+ f x