nng_inproc - intra-process transport for nng
The nng_inproc transport provides communication support between nng sockets within the same process. This may be used as an alternative to slower transports when data must be moved within the same process.
This transport tries hard to avoid copying data, and thus is very light-weight.
The inproc transport is generally built-in to the nng core, so no extra steps to use it should be necessary.
This transport uses URIs using the scheme inproc://
, followed by
an arbitrary string of text, terminated by a NUL
byte. The
entire URI must be less than NNG_MAXADDRLEN
bytes long.
Multiple URIs can be used within the same application, and they will not interfere with one another.
Two applications may also use the same URI without interfering with each other, and they will be unable to communicate with each other using that URI.
When using an nng_sockaddr
structure, the actual structure is of type
struct nng_sockaddr_inproc
. This type has the following definition:
#define NNG_AF_INPROC 1 (1)
#define NNG_MAXADDRLEN 128
typedef nng_sockaddr_inproc {
// (2)
uint16_t sa_family; // must be NNG_AF_INPROC
char sa_path[NNG_MAXADDRLEN]; // arbitrary "path"
//
}
-
The values of these macros may change, so applications should avoid depending upon their values and instead use them symbolically.
-
Other members may be present, but only those listed here are suitable for application use.
The sa_family
member will have the value NNG_AF_INPROC
.
The sa_path
member is an ASCIIZ string, and may contain any characters,
terminated by a NUL
byte.
Copyright 2017 Garrett D’Amore
Copyright 2017 Capitar IT Group BV
This document is supplied under the terms of the MIT License.