Skip to content

Commit

Permalink
Use raise and reraise instead of fail in more places in unix
Browse files Browse the repository at this point in the history
  • Loading branch information
raphael-proust authored and smorimoto committed Jun 20, 2024
1 parent cc6a0bb commit 8318397
Show file tree
Hide file tree
Showing 9 changed files with 52 additions and 52 deletions.
34 changes: 17 additions & 17 deletions src/unix/lwt_io.ml
Original file line number Diff line number Diff line change
Expand Up @@ -231,7 +231,7 @@ let perform_io : type mode. mode _channel -> int Lwt.t = fun ch ->
(function
| Unix.Unix_error (Unix.EPIPE, _, _) ->
Lwt.return 0
| exn -> Lwt.fail exn) [@ocaml.warning "-4"]
| exn -> Lwt.reraise exn) [@ocaml.warning "-4"]
else
perform ch.buffer ptr len
in
Expand Down Expand Up @@ -525,7 +525,7 @@ let make :
max = (match mode with
| Input -> 0
| Output -> size);
close = lazy(Lwt.catch close Lwt.fail);
close = lazy(Lwt.catch close Lwt.reraise);
abort_waiter = abort_waiter;
abort_wakener = abort_wakener;
main = wrapper;
Expand All @@ -537,7 +537,7 @@ let make :
perform_io,
fun pos cmd ->
try seek pos cmd
with e when Lwt.Exception_filter.run e -> Lwt.fail e
with e when Lwt.Exception_filter.run e -> Lwt.reraise e
);
} and wrapper = {
state = Idle;
Expand Down Expand Up @@ -678,7 +678,7 @@ struct
let ptr = ic.ptr in
if ptr = ic.max then
refill ic >>= function
| 0 -> Lwt.fail End_of_file
| 0 -> raise End_of_file
| _ -> read_char ic
else begin
ic.ptr <- ptr + 1;
Expand All @@ -690,7 +690,7 @@ struct
(fun () -> read_char ic >|= fun ch -> Some ch)
(function
| End_of_file -> Lwt.return_none
| exn -> Lwt.fail exn)
| exn -> Lwt.reraise exn)

let read_line ic =
let buf = Buffer.create 128 in
Expand All @@ -711,7 +711,7 @@ struct
if cr_read then Buffer.add_char buf '\r';
Lwt.return(Buffer.contents buf)
| exn ->
Lwt.fail exn)
Lwt.reraise exn)
in
read_char ic >>= function
| '\r' -> loop true
Expand All @@ -723,7 +723,7 @@ struct
(fun () -> read_line ic >|= fun ch -> Some ch)
(function
| End_of_file -> Lwt.return_none
| exn -> Lwt.fail exn)
| exn -> Lwt.reraise exn)

let unsafe_read_into' ic blit buf ofs len =
let avail = ic.max - ic.ptr in
Expand Down Expand Up @@ -771,7 +771,7 @@ struct
let rec loop ic buf ofs len =
read_into ic buf ofs len >>= function
| 0 ->
Lwt.fail End_of_file
raise End_of_file
| n ->
let len = len - n in
if len = 0 then
Expand Down Expand Up @@ -985,7 +985,7 @@ struct
if ic.max - ic.ptr < size then
refill ic >>= function
| 0 ->
Lwt.fail End_of_file
raise End_of_file
| _ ->
read_block_unsafe ic size f
else begin
Expand Down Expand Up @@ -1440,7 +1440,7 @@ let open_temp_file ?buffer ?flags ?perm ?temp_dir ?prefix ?(suffix = "") () =
Lwt.return (fname, chan))
(function
| Unix.Unix_error _ when n < 1000 -> attempt (n + 1)
| exn -> Lwt.fail exn)
| exn -> Lwt.reraise exn)
in
attempt 0

Expand Down Expand Up @@ -1468,7 +1468,7 @@ let create_temp_dir
Lwt.return name)
(function
| Unix.Unix_error (Unix.EEXIST, _, _) when n < 1000 -> attempt (n + 1)
| exn -> Lwt.fail exn)
| exn -> Lwt.reraise exn)
in
attempt 0

Expand All @@ -1489,10 +1489,10 @@ let win32_unlink fn =
(* If everything succeeded but the final removal still failed,
restore original permissions *)
Lwt_unix.chmod fn st_perm >>= fun () ->
Lwt.fail exn)
Lwt.reraise exn)
)
(fun _ -> Lwt.fail exn)
| exn -> Lwt.fail exn)
(fun _ -> Lwt.reraise exn)
| exn -> Lwt.reraise exn)

let unlink =
if Sys.win32 then
Expand Down Expand Up @@ -1549,7 +1549,7 @@ let close_socket fd =
(function
(* Occurs if the peer closes the connection first. *)
| Unix.Unix_error (Unix.ENOTCONN, _, _) -> Lwt.return_unit
| exn -> Lwt.fail exn) [@ocaml.warning "-4"])
| exn -> Lwt.reraise exn) [@ocaml.warning "-4"])
(fun () ->
Lwt_unix.close fd)

Expand All @@ -1574,7 +1574,7 @@ let open_connection ?fd ?in_buffer ?out_buffer sockaddr =
~mode:output (Lwt_bytes.write fd)))
(fun exn ->
Lwt_unix.close fd >>= fun () ->
Lwt.fail exn)
Lwt.reraise exn)

let with_close_connection f (ic, oc) =
(* If the user already tried to close the socket and got an exception, we
Expand Down Expand Up @@ -1639,7 +1639,7 @@ let establish_server_generic
(function
| Unix.Unix_error (Unix.ECONNABORTED, _, _) ->
Lwt.return `Try_again
| e -> Lwt.fail e)
| e -> Lwt.reraise e)
in

Lwt.pick [try_to_accept; should_stop] >>= function
Expand Down
10 changes: 5 additions & 5 deletions src/unix/lwt_process.cppo.ml
Original file line number Diff line number Diff line change
Expand Up @@ -378,7 +378,7 @@ let read_opt read ic =
(function
| Unix.Unix_error (Unix.EPIPE, _, _) | End_of_file ->
Lwt.return_none
| exn -> Lwt.fail exn) [@ocaml.warning "-4"]
| exn -> Lwt.reraise exn) [@ocaml.warning "-4"]

let recv_chars pr =
let ic = pr#stdout in
Expand Down Expand Up @@ -512,8 +512,8 @@ let pmap ?timeout ?env ?cwd ?stderr cmd text =
| Lwt.Canceled as exn ->
(* Cancel the getter if the sender was canceled. *)
Lwt.cancel getter;
Lwt.fail exn
| exn -> Lwt.fail exn)
Lwt.reraise exn
| exn -> Lwt.reraise exn)

let pmap_chars ?timeout ?env ?cwd ?stderr cmd chars =
let pr = open_process ?timeout ?env ?cwd ?stderr cmd in
Expand All @@ -534,8 +534,8 @@ let pmap_line ?timeout ?env ?cwd ?stderr cmd line =
| Lwt.Canceled as exn ->
(* Cancel the getter if the sender was canceled. *)
Lwt.cancel getter;
Lwt.fail exn
| exn -> Lwt.fail exn)
Lwt.reraise exn
| exn -> Lwt.reraise exn)

let pmap_lines ?timeout ?env ?cwd ?stderr cmd lines =
let pr = open_process ?timeout ?env ?cwd ?stderr cmd in
Expand Down
18 changes: 9 additions & 9 deletions src/unix/lwt_unix.cppo.ml
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,7 @@ let auto_pause timeout =

exception Timeout

let timeout d = sleep d >>= fun () -> Lwt.fail Timeout
let timeout d = sleep d >>= fun () -> raise Timeout

let with_timeout d f = Lwt.pick [timeout d; Lwt.apply f ()]

Expand Down Expand Up @@ -582,7 +582,7 @@ let wrap_syscall event ch action =
| Retry_write ->
register_action Write ch action
| e when Lwt.Exception_filter.run e ->
Lwt.fail e
Lwt.reraise e

(* +-----------------------------------------------------------------+
| Basic file input/output |
Expand Down Expand Up @@ -636,7 +636,7 @@ let wait_read ch =
Lwt.return_unit
else
register_action Read ch ignore)
Lwt.fail
Lwt.reraise

external stub_read : Unix.file_descr -> Bytes.t -> int -> int -> int = "lwt_unix_read"
external read_job : Unix.file_descr -> Bytes.t -> int -> int -> int job = "lwt_unix_read_job"
Expand Down Expand Up @@ -694,7 +694,7 @@ let wait_write ch =
Lwt.return_unit
else
register_action Write ch ignore)
Lwt.fail
Lwt.reraise

external stub_write : Unix.file_descr -> Bytes.t -> int -> int -> int = "lwt_unix_write"
external write_job : Unix.file_descr -> Bytes.t -> int -> int -> int job = "lwt_unix_write_job"
Expand Down Expand Up @@ -1034,7 +1034,7 @@ let file_exists name =
(fun e ->
match e with
| Unix.Unix_error _ -> Lwt.return_false
| _ -> Lwt.fail e) [@ocaml.warning "-4"]
| _ -> Lwt.reraise e) [@ocaml.warning "-4"]

external utimes_job : string -> float -> float -> unit job =
"lwt_unix_utimes_job"
Expand Down Expand Up @@ -1140,7 +1140,7 @@ struct
(fun e ->
match e with
| Unix.Unix_error _ -> Lwt.return_false
| _ -> Lwt.fail e) [@ocaml.warning "-4"]
| _ -> Lwt.reraise e) [@ocaml.warning "-4"]

end

Expand Down Expand Up @@ -1408,7 +1408,7 @@ let files_of_directory path =
(fun () -> readdir_n handle chunk_size)
(fun exn ->
closedir handle >>= fun () ->
Lwt.fail exn) >>= fun entries ->
Lwt.reraise exn) >>= fun entries ->
if Array.length entries < chunk_size then begin
state := LDS_done;
closedir handle >>= fun () ->
Expand All @@ -1423,7 +1423,7 @@ let files_of_directory path =
(fun () -> readdir_n handle chunk_size)
(fun exn ->
closedir handle >>= fun () ->
Lwt.fail exn) >>= fun entries ->
Lwt.reraise exn) >>= fun entries ->
if Array.length entries < chunk_size then begin
state := LDS_done;
closedir handle >>= fun () ->
Expand Down Expand Up @@ -2395,7 +2395,7 @@ let () =
let _waitpid flags pid =
Lwt.catch
(fun () -> Lwt.return (Unix.waitpid flags pid))
Lwt.fail
Lwt.reraise

let waitpid =
if Sys.win32 then
Expand Down
6 changes: 3 additions & 3 deletions test/unix/test_lwt_bytes.ml
Original file line number Diff line number Diff line change
Expand Up @@ -793,7 +793,7 @@ let suite = suite "lwt_bytes" [
)
(function
| Invalid_argument _message -> Lwt.return_true
| exn -> Lwt.fail exn
| exn -> Lwt.reraise exn
)
end;

Expand Down Expand Up @@ -825,7 +825,7 @@ let suite = suite "lwt_bytes" [
)
(function
| Invalid_argument _message -> Lwt.return_true
| exn -> Lwt.fail exn
| exn -> Lwt.reraise exn
)
end;

Expand All @@ -839,7 +839,7 @@ let suite = suite "lwt_bytes" [
)
(function
| Invalid_argument _message -> Lwt.return_true
| exn -> Lwt.fail exn
| exn -> Lwt.reraise exn
)
end;
]
2 changes: 1 addition & 1 deletion test/unix/test_lwt_engine.ml
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ let timing_tests = [
| Lwt_unix.Timeout ->
Lwt.return (Unix.gettimeofday ())
| exn ->
Lwt.fail exn)
Lwt.reraise exn)

>>= fun stop ->

Expand Down
6 changes: 3 additions & 3 deletions test/unix/test_lwt_io.ml
Original file line number Diff line number Diff line change
Expand Up @@ -320,7 +320,7 @@ let suite = suite "lwt_io" [
exceptions_observed := !exceptions_observed + 1;
Lwt.return_unit
| exn ->
Lwt.fail exn) [@ocaml.warning "-4"]
Lwt.reraise exn) [@ocaml.warning "-4"]
in

let fd_r, fd_w = Lwt_unix.pipe () in
Expand Down Expand Up @@ -353,7 +353,7 @@ let suite = suite "lwt_io" [
let filename = ref "." in
let wrap f (filename', chan) = filename := filename'; f chan in
let write_data chan = Lwt_io.write chan "test file content" in
let write_data_fail _ = Lwt.fail Dummy_error in
let write_data_fail _ = Lwt.fail Dummy_error in
Lwt_io.with_temp_file (wrap write_data) ~prefix >>= fun _ ->
let no_temps1 = not (Sys.file_exists !filename) in
Lwt.catch
Expand Down Expand Up @@ -422,7 +422,7 @@ let suite = suite "lwt_io" [
(function
| Unix.Unix_error (Unix.EISDIR, "file_length", ".") ->
Lwt.return_true
| exn -> Lwt.fail exn)
| exn -> Lwt.reraise exn)
end;

test "input channel of_bytes initial position"
Expand Down
18 changes: 9 additions & 9 deletions test/unix/test_lwt_unix.ml
Original file line number Diff line number Diff line change
Expand Up @@ -172,7 +172,7 @@ let utimes_tests = [
(function
| Unix.Unix_error (Unix.ENOENT, "utimes", _) -> Lwt.return_unit
| Unix.Unix_error (Unix.EUNKNOWNERR _, "utimes", _) -> Lwt.return_unit
| e -> Lwt.fail e) [@ocaml.warning "-4"] >>= fun () ->
| e -> Lwt.reraise e) [@ocaml.warning "-4"] >>= fun () ->
Lwt.return_true);
]

Expand Down Expand Up @@ -218,7 +218,7 @@ let readdir_tests =
Lwt.return (Some filename))
(function
| End_of_file -> Lwt.return_none
| exn -> Lwt.fail exn)
| exn -> Lwt.reraise exn)
>>= function
| None -> Lwt.return acc
| Some filename -> loop (filename::acc)
Expand Down Expand Up @@ -305,7 +305,7 @@ let readdir_tests =
(function
| Unix.Unix_error (Unix.EBADF, tag', _) when tag' = tag ->
Lwt.return_true
| exn -> Lwt.fail exn) [@ocaml.warning "-4"]
| exn -> Lwt.reraise exn) [@ocaml.warning "-4"]
in

Lwt_list.for_all_s (fun (tag, t) -> expect_ebadf tag t)
Expand Down Expand Up @@ -711,7 +711,7 @@ let writev_tests =
Lwt.return_false)
(function
| Invalid_argument _ -> Lwt.return_true
| e -> Lwt.fail e)
| e -> Lwt.reraise e)
in

let close write_fd = fun () ->
Expand Down Expand Up @@ -963,7 +963,7 @@ let bind_tests =
| Unix.Unix_error (Unix.EADDRINUSE, "bind", _)
| Unix.Unix_error (Unix.EISDIR, "bind", _) as exn ->
if attempts <= 1 then
Lwt.fail exn
Lwt.reraise exn
else
bind_loop (attempts - 1)
| Unix.Unix_error (Unix.EPERM, "bind", _) ->
Expand All @@ -972,8 +972,8 @@ let bind_tests =
test should add a check for WSL by checking for the existence
of /proc/version, reading it, and checking its contents for the
string "WSL". *)
Lwt.fail Skip
| e -> Lwt.fail e) [@ocaml.warning "-4"]
raise Skip
| e -> Lwt.reraise e) [@ocaml.warning "-4"]
in

Lwt.finalize
Expand Down Expand Up @@ -1014,7 +1014,7 @@ let bind_tests =
Lwt.return_false)
(function
| Unix.Unix_error (Unix.EBADF, _, _) -> Lwt.return_true
| e -> Lwt.fail e) [@ocaml.warning "-4"]);
| e -> Lwt.reraise e) [@ocaml.warning "-4"]);

test "bind: aborted"
(fun () ->
Expand All @@ -1028,7 +1028,7 @@ let bind_tests =
Lwt.return_false)
(function
| Exit -> Lwt.return_true
| e -> Lwt.fail e))
| e -> Lwt.reraise e))
(fun () -> Lwt_unix.close socket));
]

Expand Down
Loading

0 comments on commit 8318397

Please sign in to comment.