diff options
author | Laurent Bercot <ska-skaware@skarnet.org> | 2017-01-25 15:52:18 +0000 |
---|---|---|
committer | Laurent Bercot <ska-skaware@skarnet.org> | 2017-01-25 15:52:18 +0000 |
commit | 00c9cb1b22cc17c4db573e0e613a5f116ff0092e (patch) | |
tree | 53178b2c52c6e97c6193f73378f3c5e5a781a914 /src/libstddjb/netstring_put.c | |
parent | 2746b131aa482ac17c94bc6b82e58dbcc1b752cf (diff) | |
download | skalibs-00c9cb1b22cc17c4db573e0e613a5f116ff0092e.tar.xz |
More work on the types. This commit builds but has errors.
Rework src/headers entirely: build skalibs/types.h
Convert skalibs/fmtscan.h types.
Propagate changes until it builds.
There are a lot of incompatible pointer issues remaining, those will be fixed with the buffer overhaul.
Diffstat (limited to 'src/libstddjb/netstring_put.c')
-rw-r--r-- | src/libstddjb/netstring_put.c | 21 |
1 files changed, 11 insertions, 10 deletions
diff --git a/src/libstddjb/netstring_put.c b/src/libstddjb/netstring_put.c index 5a27b25..692d2fc 100644 --- a/src/libstddjb/netstring_put.c +++ b/src/libstddjb/netstring_put.c @@ -1,34 +1,35 @@ /* ISC license. */ +#include <sys/types.h> #include <errno.h> +#include <skalibs/uint64.h> #include <skalibs/buffer.h> #include <skalibs/netstring.h> -#include <skalibs/uint.h> -int netstring_put (buffer *b, char const *s, unsigned int len, unsigned int *written) +int netstring_put (buffer *b, char const *s, size_t len, size_t *written) { - char fmt[UINT_FMT] ; - unsigned int n = uint_fmt(fmt, len) ; + char fmt[UINT64_FMT] ; + size_t n = uint64_fmt(fmt, len) ; if (*written > len + n + 2) return (errno = EINVAL, 0) ; fmt[n] = ':' ; if (*written < n + 1) { - unsigned int w = *written ; - int r = buffer_putall(b, fmt, n+1, &w) ; + size_t w = *written ; + ssize_t r = buffer_putall(b, fmt, n+1, &w) ; if (r < 0) return (*written = w, 0) ; *written = n+1 ; } if (*written < n+1 + len) { - unsigned int w = *written - (n+1) ; - int r = buffer_putall(b, s, len, &w) ; + size_t w = *written - (n+1) ; + ssize_t r = buffer_putall(b, s, len, &w) ; *written = w + (n+1) ; if (r < 0) return (*written = n+1 + w, 0) ; *written = n+1 + len ; } { - unsigned int w = 0 ; - int r = buffer_putall(b, ",", 1, &w) ; + size_t w = 0 ; + ssize_t r = buffer_putall(b, ",", 1, &w) ; if (r < 0) return 0 ; } *written = 0 ; |