From: Claudio Sacerdoti Coen Date: Mon, 29 May 2006 17:10:14 +0000 (+0000) Subject: ensure connections get closed after having been served X-Git-Tag: 0.4.95@7852~1408 X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=commitdiff_plain;h=a72bdf47bf2ed2f00c7d3b5f1d53d0264d5efd7f;p=helm.git ensure connections get closed after having been served --- diff --git a/daemons/rdfly/rdfly.ml b/daemons/rdfly/rdfly.ml index b9a79d139..18c2e1587 100644 --- a/daemons/rdfly/rdfly.ml +++ b/daemons/rdfly/rdfly.ml @@ -152,7 +152,7 @@ let password = get_option "rdfly.mysql_connection.password";; let user = get_option "rdfly.mysql_connection.user";; let daemonport = Helm_registry.get_int "rdfly.port";; -let callback (req: Http_types.request) ch = +let callback ((req: Http_types.request), ch) = try debug_print ("Connection from " ^ req#clientAddr) ; debug_print ("Received request: " ^ req#uri) ; @@ -180,6 +180,11 @@ let callback (req: Http_types.request) ch = | exc -> return_html_error ("Uncaught exception: " ^ (Printexc.to_string exc)) ch +let callback req ch = + HExtlib.finally + (fun () -> try close_out ch with Sys_error _ -> ()) + callback (req, ch) + let main () = Sys.catch_break true; try