nanomsg next generation NNG  
Home GitHub Documentation

This documentation is for version 0.5.0 of nng, but the latest released version is v1.8.0. see the documentation for v1.8.0 for the most up-to-date information.
nng_send(3)

SYNOPSIS

#include <nng/nng.h>

int nng_send(nng_socket s, void *data, size_t size, int flags);

DESCRIPTION

The nng_send() sends a message containing the data of length size using the socket s.

The semantics of what sending a message means vary from protocol to protocol, so examination of the protocol documentation is encouraged. (For example, with an nng_pub(7) socket the data is broadcast, so that any peers who have a suitable subscription will be able to receive it using nng_recv(3) or a similar function.) Furthermore, some protocols may not support sending data (such as nng_sub(7)) or may require other conditions. (For example, nng_rep(7) sockets cannot normally send data, which are responses to requests, until they have first received a request.)

The flags may contain either of (or neither of) the following values:

NNG_FLAG_NONBLOCK

The function returns immediately, regardless of whether the socket is able to accept the data or not. If the socket is unable to accept the data (such as if backpressure exists because the peers are consuming messages too slowly, or no peer is present), then the function will return with NNG_EAGAIN. If this flag is not specified, then the function will block if such a condition exists.

NNG_FLAG_ALLOC

The data was allocated using nng_alloc(3), or was obtained from a call to nng_recv(3) with the NNG_FLAG_ALLOC flag. If this function returns success, then the data is "owned" by the function, and it will assume responsibility for calling nng_free(3) when it is no longer needed. In the absence of this flag, the data is copied by the implementation before the function returns to the caller.

The NNG_FLAG_ALLOC flag can be used to reduce data copies, thereby increasing performance.
Regardless of the presence or absence of NNG_FLAG_NONBLOCK, there may be queues between the sender and the receiver. Furthermore, there is no guarantee that the message has actually been delivered. Finally, with some protocols, the semantic is implictly NNG_FLAG_NONBLOCK, such as with nng_pub(7) sockets, which are best-effort delivery only.
When using NNG_FLAG_ALLOC, it is important that the value of size match the actual allocated size of the data. Using an incorrect size results in unspecified behavior, which may include heap corruption, program crashes, or transdimensional mutation of the program’s author.

RETURN VALUES

This function returns 0 on success, and non-zero otherwise.

ERRORS

NNG_EAGAIN

The socket s cannot accept data for sending.

NNG_ECLOSED

The socket s is not open.

NNG_EINVAL

An invalid set of flags was specified.

NNG_EMSGSIZE

The value of size is too large.

NNG_ENOMEM

Insufficient memory is available.

NNG_ENOTSUP

The protocol for socket s does not support sending.

NNG_ESTATE

The socket s cannot send data in this state.

NNG Reference Manual v0.5.0 © 2019 Staysail Systems, Inc, © 2018 Capitar IT Group BV
This document is supplied under the MIT License.
nanomsg™ and nng™ are trademarks of Garrett D'Amore.