Provided by: libowfat-dev_0.32-4.1build1_amd64 bug

NAME

       iob_send - send I/O batch

SYNTAX

       #include <libowfat/iob.h>

       int64 iob_send(int64 s,io_batch* b);

DESCRIPTION

       iob_send sends the (rest of) b over the socket s.

       iob_send  returns  the number of bytes written, 0 if there were no more bytes to be written in the batch,
       -1 for EAGAIN, or -3 for a permanent error (for example "connection reset by peer").

       The normal usage pattern is using io_wait to know  when  a  descriptor  is  writable,  and  then  calling
       iob_send until it returns 0, -1 or -3.

       If  it  returns 0, terminate the loop (everything was written OK).  If it returns -1, call io_wait again.
       If it returned -3, signal an error and close the socket.

       The benefit of the I/O batch API is that it exploits platform specific APIs like FreeBSD's sendfile.  The
       file contents will always be sent in a way that allows the operating systems to perform  zero  copy  TCP,
       and  the  buffers  will always be sent using as few syscalls as possible and avoiding unnecessary copying
       (using writev).

SEE ALSO

       iob_reset(3), iob_send(3), iob_addbuf(3), iob_adds_free(3), iob_addfile(3), iob_prefetch(3)

                                                                                                     iob_send(3)