This documentation is for the TIP (development tree) of NNG and may represent unreleased changes or functionality that is experimental, and is subject to change before release. The latest released version is v1.8.0. See the documentation for v1.8.0 for the most up-to-date information.

nng_stream_recv(3str)

NAME

nng_stream_recv - receive from byte stream

SYNOPSIS

#include <nng/nng.h>

void nng_stream_recv(nng_stream *s, nng_aio *aio);

DESCRIPTION

The nng_stream_recv() function starts an asynchronous receive from the byte stream s into the scatter/gather vector located in the asynchronous I/O structure aio.

The nng_aio_set_iov() function must have been called first, to set the scatter/gather vector for aio.

This function returns immediately, with no return value. Completion of the operation is signaled via the aio, and the final result may be obtained via nng_aio_result(). That result will either be zero or an error code.

The I/O operation completes as soon as at least one byte has been received, or an error has occurred. Therefore, the number of bytes read may be less than requested. The actual number of bytes read can be determined with nng_aio_count().

RETURN VALUES

None.

ERRORS

NNG_ECANCELED

The operation was canceled.

NNG_ECLOSED

The connection was closed.

NNG_ECONNRESET

The peer closed the connection.

NNG_ECONNSHUT

Remote peer shutdown after sending data.

NNG_EINVAL

The aio does not contain a valid scatter/gather vector.

NNG_ENOMEM

Insufficient free memory to perform the operation.

NNG_ETIMEDOUT

Timeout waiting for data from the connection.

SEE ALSO