Legend:
Library
Module
Module type
Parameter
Class
Class type
Library
Module
Module type
Parameter
Class
Class type
module Logger : Async_unix.Log.Global_intf
val sexp_of_t : t -> Sexplib0.Sexp.t
val create :
?max_buffer_size:int ->
?buf_len:int ->
?write_timeout:Core.Time_ns.Span.t ->
?time_source:[> Core.read ] Async_kernel.Time_source.T1.t ->
Async_unix.Fd.t ->
t
create ?max_buffer_size ?buf_len ?write_timeout fd
creates a new writer.
The writer doesn't flush automatically and the user is responsible for calling flush
, which triggers a write system call if needed.
val write_timeout : t -> Core.Time_ns.Span.t
write_timeout
is the maximum amount of time the writer will wait when attempting to write data to the underlying file descriptor.
val buffer_size : t -> int
val max_buffer_size : t -> int
val time_source : t -> Async_kernel.Time_source.t
val monitor : t -> Async_kernel.Monitor.t
monitor
returns the async monitor used by Output_channel
for performing all write operations.
val remote_closed : t -> unit Async_kernel.Deferred.t
remote_closed
is a deferred that's resolved when the consumer that's reading the bytes written to the Output_channel is closed, i.e. the channel has received an EPIPE or ECONNRESET when it attempts to perform a write.
val is_closed : t -> bool
val is_open : t -> bool
val close_started : t -> unit Async_kernel.Deferred.t
val close_finished : t -> unit Async_kernel.Deferred.t
val write_bigstring : t -> ?pos:int -> ?len:int -> Core.Bigstring.t -> unit
write_bigstring
copies the bigstring into the channel's internal buffer. It is safe to modify the bigstring once write_bigstring
returns.
val schedule_bigstring : t -> ?pos:int -> ?len:int -> Core.Bigstring.t -> unit
val write : t -> ?pos:int -> ?len:int -> string -> unit
write
copies the string into the channel's internal buffer. The string will surface the next time the writer schedules a write.
val write_string : t -> ?pos:int -> ?len:int -> string -> unit
val write_char : t -> char -> unit
val writef : t -> ('a, unit, string, unit) Core.format4 -> 'a
val close : t -> unit Async_kernel.Deferred.t
close
will close the underlying file descriptor after waiting for the writer to be flushed.
val schedule_flush : t -> unit
schedule_flush
will schedule a write system call if one is needed.
module Flush_result : sig ... end
val flushed_or_fail : t -> Flush_result.t Async_kernel.Deferred.t
flushed_or_fail t
returns a Deferred that is resolved when all previous writes complete, or if any of the write operations fail.
val flushed : t -> unit Async_kernel.Deferred.t
flushed t
returns a deferred that will get resolved when all previous writes have finished. Unlike flushed_or_fail
if a write call fails then the deferred will never be resolved.
val flush : t -> unit Async_kernel.Deferred.t
flush
schedules a write system call if one is needed and returns a deferred that is resolved when all prior writes have finished. If a write call fails then the deferred will never be resolved.
val flush_or_fail : t -> Flush_result.t Async_kernel.Deferred.t
flush_or_fail
schedules a write system call if one is needed and returns a deferred that is resolved when all previous writes complete, or if any of the write operations fail.
val pipe : t -> string Async_kernel.Pipe.Writer.t
val of_pipe :
?max_buffer_size:int ->
?buf_len:int ->
Core.Info.t ->
string Async_kernel.Pipe.Writer.t ->
(t * unit Async_kernel.Deferred.t) Async_kernel.Deferred.t