diff options
| author | Garrett D'Amore <garrett@damore.org> | 2017-08-29 14:17:11 -0700 |
|---|---|---|
| committer | Garrett D'Amore <garrett@damore.org> | 2017-09-22 12:33:03 -0700 |
| commit | f04cfd27e2d67b0fc89b079410fc11b55b6d1979 (patch) | |
| tree | b177a2fd79de4f1293e54e7a4d6990a135f0d65b /src/core | |
| parent | 72147bcfbdc568bc58877e0904b92013d82a2acd (diff) | |
| download | nng-f04cfd27e2d67b0fc89b079410fc11b55b6d1979.tar.gz nng-f04cfd27e2d67b0fc89b079410fc11b55b6d1979.tar.bz2 nng-f04cfd27e2d67b0fc89b079410fc11b55b6d1979.zip | |
Add improved getopt functions, pass integers by value.
Diffstat (limited to 'src/core')
| -rw-r--r-- | src/core/options.c | 47 | ||||
| -rw-r--r-- | src/core/options.h | 12 | ||||
| -rw-r--r-- | src/core/socket.c | 4 |
3 files changed, 47 insertions, 16 deletions
diff --git a/src/core/options.c b/src/core/options.c index 4027564c..76025710 100644 --- a/src/core/options.c +++ b/src/core/options.c @@ -123,45 +123,70 @@ nni_setopt_size(size_t *sp, const void *v, size_t sz, size_t minv, size_t maxv) } int -nni_getopt_usec(nni_duration *ptr, void *val, size_t *sizep) +nni_getopt_usec(nni_duration u, void *val, size_t *sizep) { - size_t sz = sizeof(*ptr); + size_t sz = sizeof(u); if (sz > *sizep) { sz = *sizep; } - *sizep = sizeof(*ptr); - memcpy(val, ptr, sz); + *sizep = sizeof(u); + memcpy(val, &u, sz); return (0); } int -nni_getopt_int(int *ptr, void *val, size_t *sizep) +nni_getopt_int(int i, void *val, size_t *sizep) { - size_t sz = sizeof(*ptr); + size_t sz = sizeof(i); if (sz > *sizep) { sz = *sizep; } - *sizep = sizeof(*ptr); - memcpy(val, ptr, sz); + *sizep = sizeof(i); + memcpy(val, &i, sz); return (0); } int -nni_getopt_size(size_t *ptr, void *val, size_t *sizep) +nni_getopt_u64(const uint64_t u, void *val, size_t *sizep) { - size_t sz = sizeof(*ptr); + size_t sz = sizeof(u); if (sz > *sizep) { sz = *sizep; } - *sizep = sizeof(*ptr); + *sizep = sizeof(u); + memcpy(val, &u, sz); + return (0); +} + +int +nni_getopt_str(const char *ptr, void *val, size_t *sizep) +{ + size_t len = strlen(ptr) + 1; + size_t sz; + + sz = (len > *sizep) ? *sizep : len; + *sizep = len; memcpy(val, ptr, sz); return (0); } int +nni_getopt_size(size_t u, void *val, size_t *sizep) +{ + size_t sz = sizeof(u); + + if (sz > *sizep) { + sz = *sizep; + } + *sizep = sizeof(u); + memcpy(val, &u, sz); + return (0); +} + +int nni_setopt_buf(nni_msgq *mq, const void *val, size_t sz) { int len; diff --git a/src/core/options.h b/src/core/options.h index 03a6e37e..ed091703 100644 --- a/src/core/options.h +++ b/src/core/options.h @@ -26,7 +26,7 @@ extern int nni_getopt_buf(nni_msgq *, void *, size_t *); extern int nni_setopt_usec(nni_duration *, const void *, size_t); // nni_getopt_duration gets the duration. -extern int nni_getopt_usec(nni_duration *, void *, size_t *); +extern int nni_getopt_usec(nni_duration, void *, size_t *); // nni_setopt_int sets an integer, which must be between the minimum and // maximum values (inclusive). @@ -36,7 +36,13 @@ extern int nni_setopt_int(int *, const void *, size_t, int, int); #define NNI_MININT ((int) -2147483648) // nni_getopt_int gets an integer. -extern int nni_getopt_int(int *, void *, size_t *); +extern int nni_getopt_int(int, void *, size_t *); + +// nni_getopt_u64 gets an unsigned 64 bit number. +extern int nni_getopt_u64(uint64_t, void *, size_t *); + +// nni_getopt_str gets a C style string. +extern int nni_getopt_str(const char *, void *, size_t *); // nni_setopt_size sets a size_t option. extern int nni_setopt_size(size_t *, const void *, size_t, size_t, size_t); @@ -47,7 +53,7 @@ extern int nni_setopt_size(size_t *, const void *, size_t, size_t, size_t); #define NNI_MAXSZ ((size_t) 0xffffffff) // nni_getopt_size obtains a size_t option. -extern int nni_getopt_size(size_t *, void *, size_t *); +extern int nni_getopt_size(size_t, void *, size_t *); // nni_getopt_fd obtains a notification file descriptor. extern int nni_getopt_fd(nni_sock *, nni_notifyfd *, int, void *, size_t *); diff --git a/src/core/socket.c b/src/core/socket.c index 01fd9a0c..03ae5a9d 100644 --- a/src/core/socket.c +++ b/src/core/socket.c @@ -960,9 +960,9 @@ nni_sock_getopt(nni_sock *s, int opt, void *val, size_t *szp) } else if (opt == nng_optid_recvfd) { rv = nni_getopt_fd(s, &s->s_recv_fd, NNG_EV_CAN_RCV, val, szp); } else if (opt == nng_optid_reconnmint) { - rv = nni_getopt_usec(&s->s_reconn, val, szp); + rv = nni_getopt_usec(s->s_reconn, val, szp); } else if (opt == nng_optid_reconnmaxt) { - rv = nni_getopt_usec(&s->s_reconnmax, val, szp); + rv = nni_getopt_usec(s->s_reconnmax, val, szp); } else { NNI_LIST_FOREACH (&s->s_options, sopt) { if (sopt->opt == opt) { |
