diff options
| author | Garrett D'Amore <garrett@damore.org> | 2018-04-04 13:36:54 -0700 |
|---|---|---|
| committer | Garrett D'Amore <garrett@damore.org> | 2018-04-10 15:40:00 -0700 |
| commit | 5f7289e1f8e1427c9214c8e3e96ad56b1f868d53 (patch) | |
| tree | 39debf4ecde234b2a0be19c9cb15628cc32c2edb /src/nng.c | |
| parent | 56f1bf30e61c53646dd2f8425da7c7fa0d97b3e1 (diff) | |
| download | nng-5f7289e1f8e1427c9214c8e3e96ad56b1f868d53.tar.gz nng-5f7289e1f8e1427c9214c8e3e96ad56b1f868d53.tar.bz2 nng-5f7289e1f8e1427c9214c8e3e96ad56b1f868d53.zip | |
fixes #334 Separate context for state machines from sockets
This provides context support for REQ and REP sockets.
More discussion around this is in the issue itself.
Optionally we would like to extend this to the surveyor pattern.
Note that we specifically do not support pollable descriptors
for non-default contexts, and the results of using file descriptors
for polling (NNG_OPT_SENDFD and NNG_OPT_RECVFD) is undefined.
In the future, it might be nice to figure out how to factor in
optional use of a message queue for users who want more buffering,
but we think there is little need for this with cooked mode.
Diffstat (limited to 'src/nng.c')
| -rw-r--r-- | src/nng.c | 120 |
1 files changed, 120 insertions, 0 deletions
@@ -220,6 +220,126 @@ nng_send_aio(nng_socket sid, nng_aio *aio) } int +nng_ctx_open(nng_ctx *idp, nng_socket sid) +{ + nni_sock *sock; + nni_ctx * ctx; + int rv; + + if ((rv = nni_sock_find(&sock, sid)) != 0) { + return (rv); + } + if ((rv = nni_ctx_open(&ctx, sock)) != 0) { + nni_sock_rele(sock); + return (rv); + } + *idp = nni_ctx_id(ctx); + nni_ctx_rele(ctx); + nni_sock_rele(sock); + return (0); +} + +int +nng_ctx_close(nng_ctx cid) +{ + int rv; + nni_ctx *ctx; + + if ((rv = nni_ctx_find(&ctx, cid, true)) != 0) { + return (rv); + } + // no release, close releases implicitly. + nni_ctx_close(ctx); + return (0); +} + +void +nng_ctx_recv(nng_ctx cid, nng_aio *aio) +{ + int rv; + nni_ctx *ctx; + + if ((rv = nni_ctx_find(&ctx, cid, false)) != 0) { + nni_aio_finish_error(aio, rv); + return; + } + nni_ctx_recv(ctx, aio); + nni_ctx_rele(ctx); +} + +void +nng_ctx_send(nng_ctx cid, nng_aio *aio) +{ + int rv; + nni_ctx *ctx; + + if ((rv = nni_ctx_find(&ctx, cid, false)) != 0) { + nni_aio_finish_error(aio, rv); + return; + } + nni_ctx_send(ctx, aio); + nni_ctx_rele(ctx); +} + +static int +nng_ctx_getx(nng_ctx id, const char *n, void *v, size_t *szp, int t) +{ + nni_ctx *ctx; + int rv; + + if ((rv = nni_init()) != 0) { + return (rv); + } + if ((rv = nni_ctx_find(&ctx, id, false)) != 0) { + return (rv); + } + rv = nni_ctx_getopt(ctx, n, v, szp, t); + nni_ctx_rele(ctx); + return (rv); +} + +int +nng_ctx_getopt(nng_ctx id, const char *name, void *val, size_t *szp) +{ + return (nng_ctx_getx(id, name, val, szp, NNI_TYPE_OPAQUE)); +} + +int +nng_ctx_getopt_bool(nng_ctx id, const char *name, bool *vp) +{ + size_t sz = sizeof(*vp); + return (nng_ctx_getx(id, name, vp, &sz, NNI_TYPE_BOOL)); +} + +int +nng_ctx_getopt_int(nng_ctx id, const char *name, int *vp) +{ + size_t sz = sizeof(*vp); + return (nng_ctx_getx(id, name, vp, &sz, NNI_TYPE_INT32)); +} + +int +nng_ctx_getopt_size(nng_ctx id, const char *name, size_t *vp) +{ + size_t sz = sizeof(*vp); + return (nng_ctx_getx(id, name, vp, &sz, NNI_TYPE_SIZE)); +} + +int +nng_ctx_getopt_string(nng_ctx id, const char *name, char **vp) +{ + size_t sz = sizeof(*vp); + return (nng_ctx_getx(id, name, vp, &sz, NNI_TYPE_STRING)); +} + +int +nng_ctx_getopt_ms(nng_ctx id, const char *name, nng_duration *vp) +{ + size_t sz = sizeof(*vp); + return (nng_ctx_getx(id, name, vp, &sz, NNI_TYPE_DURATION)); +} + +int nng_dial(nng_socket sid, const char *addr, nng_dialer *dp, int flags) { nni_ep * ep; |
