mirror of
https://github.com/c-cube/tiny_httpd.git
synced 2025-12-09 12:45:40 -05:00
Merge pull request #22 from craff/master
Unix.accept may raise an exception
This commit is contained in:
commit
ac05b9eaa1
1 changed files with 16 additions and 11 deletions
|
|
@ -1088,17 +1088,22 @@ let run (self:t) : (unit,_) result =
|
||||||
while self.running do
|
while self.running do
|
||||||
(* limit concurrency *)
|
(* limit concurrency *)
|
||||||
Sem_.acquire 1 self.sem_max_connections;
|
Sem_.acquire 1 self.sem_max_connections;
|
||||||
let client_sock, _ = Unix.accept sock in
|
try
|
||||||
self.new_thread
|
let client_sock, _ = Unix.accept sock in
|
||||||
(fun () ->
|
self.new_thread
|
||||||
try
|
(fun () ->
|
||||||
handle_client_ self client_sock;
|
try
|
||||||
Sem_.release 1 self.sem_max_connections;
|
handle_client_ self client_sock;
|
||||||
with e ->
|
Sem_.release 1 self.sem_max_connections;
|
||||||
(try Unix.close client_sock with _ -> ());
|
with e ->
|
||||||
Sem_.release 1 self.sem_max_connections;
|
(try Unix.close client_sock with _ -> ());
|
||||||
raise e
|
Sem_.release 1 self.sem_max_connections;
|
||||||
);
|
raise e
|
||||||
|
);
|
||||||
|
with e ->
|
||||||
|
_debug (fun k -> k
|
||||||
|
"Unix.accept or Thread.create raised an exception: %s"
|
||||||
|
(Printexc.to_string e))
|
||||||
done;
|
done;
|
||||||
Ok ()
|
Ok ()
|
||||||
with e -> Error e
|
with e -> Error e
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue