table of contents
NETREAD(3) | Common Library Functions | NETREAD(3) |
NAME¶
netread - receive a message from a socket
SYNOPSIS¶
#include "net.h"
int netread (int s, char *buf, int nbytes);
ssize_t netread_timeout (int s, void *buf, size_t nbytes, int timeout);
DESCRIPTION¶
netread receives a message from a socket. It overcomes the message fragmentation problem and always waits for all requested bytes to arrive or a timeout/error occurs.
RETURN VALUE¶
This routine returns the number of bytes if the operation was successful, 0 if the connection was closed by the remote end or -1 if the operation failed. In the latter case, serrno is set appropriately.
ERRORS¶
- EINTR
- The function was interrupted by a signal.
- EBADF
- s is not a valid descriptor.
- EAGAIN
- The socket is non-blocking and there is no message available.
- EFAULT
- buf is not a valid pointer.
- EINVAL
- nbytes is negative or zero.
- ENOTSOCK
- s is not a socket.
- SECONNDROP
- Connection closed by remote end.
- SETIMEDOUT
- Timed out.
SEE ALSO¶
recv(2), neterror(3)
AUTHOR¶
LCG Grid Deployment Team
$Date: 2005/03/29 09:27:19 $ | LCG |