Eio_unix.FdA safe wrapper for Unix.file_descr.
A wrapper around a Unix.file_descr.
val of_unix :
sw:Eio.Std.Switch.t ->
?blocking:bool ->
?seekable:bool ->
close_unix:bool ->
Unix.file_descr ->
tof_unix ~sw ~close_unix fd wraps fd.
val of_unix_list : sw:Eio.Std.Switch.t -> Unix.file_descr list -> t listof_unix_list ~sw fds is like List.map (of_unix ~sw ~close_unix:true) fds, except that if sw is off then it closes all the FDs.
val use : t -> (Unix.file_descr -> 'a) -> if_closed:(unit -> 'a) -> 'ause t fn ~if_closed calls fn wrapped_fd, ensuring that wrapped_fd will not be closed before fn returns.
If t is already closed, it returns if_closed () instead.
val use_exn : string -> t -> (Unix.file_descr -> 'a) -> 'ause_exn op t fn calls fn wrapped_fd, ensuring that wrapped_fd will not be closed before fn returns.
If t is already closed, it raises an exception, using op as the name of the failing operation.
val use_exn_list : string -> t list -> (Unix.file_descr list -> 'a) -> 'ause_exn_list op fds fn calls use_exn on each FD in fds, calling fn wrapped_fds on the results.
val close : t -> unitclose t marks t as closed, so that use can no longer be used to start new operations.
The wrapped FD will be closed once all current users of the FD have finished (unless close_unix = false).
Has no effect if t is already closed.
val remove : t -> Unix.file_descr optionremove t marks t as closed, so that use can no longer be used to start new operations.
It then waits for all current users of the wrapped FD to finish using it, and then returns the FD.
This operation suspends the calling fiber and so must run from an Eio fiber. It does not allow itself to be cancelled, since it takes ownership of the FD and that would be leaked if it aborted.
Returns None if t is closed by another fiber first.
val is_blocking : t -> boolis_blocking t returns the value of blocking passed to of_unix.
If not known, it first probes for it (and if the FD is already closed, returns false).
val is_seekable : t -> boolis_seekable t returns the value of seekable passed to of_unix.
If not known, it first probes for it (and if the FD is already closed, returns false).
val stdin : tval stdout : tval stderr : t