From 56066894b7d14f71aeba8379f0d6e5961dee733e Mon Sep 17 00:00:00 2001 From: Laurent Bercot Date: Fri, 23 Jun 2023 14:44:54 +0000 Subject: Apply fixes suggested by jjk Signed-off-by: Laurent Bercot --- src/include/skalibs/siovec.h | 1 + src/libstddjb/buffer_get.c | 9 +++++---- src/libstddjb/buffer_getv.c | 5 +++-- src/libstddjb/slurpn.c | 2 +- 4 files changed, 10 insertions(+), 7 deletions(-) (limited to 'src') diff --git a/src/include/skalibs/siovec.h b/src/include/skalibs/siovec.h index 46d9a81..5a64be0 100644 --- a/src/include/skalibs/siovec.h +++ b/src/include/skalibs/siovec.h @@ -16,5 +16,6 @@ extern unsigned int siovec_trunc (struct iovec *, unsigned int, size_t) ; extern size_t siovec_bytechr (struct iovec const *, unsigned int, char) ; extern size_t siovec_bytein (struct iovec const *, unsigned int, char const *, size_t) ; +extern size_t siovec_search (struct iovec const *, unsigned int, char const *, size_t) ; #endif diff --git a/src/libstddjb/buffer_get.c b/src/libstddjb/buffer_get.c index fbc0de3..6fe394d 100644 --- a/src/libstddjb/buffer_get.c +++ b/src/libstddjb/buffer_get.c @@ -1,12 +1,13 @@ /* ISC license. */ -#include +#include + +#include #include ssize_t buffer_get (buffer *b, char *s, size_t len) { size_t w = 0 ; - int r = buffer_getall(b, s, len, &w) ; - return r == -1 ? errno == EPIPE ? (errno = 0, w) : -1 : - !r ? (errno = EWOULDBLOCK, -1) : w ; + ssize_t r = unsanitize_read(buffer_getall(b, s, len, &w)) ; + return r < 0 ? r : w ; } diff --git a/src/libstddjb/buffer_getv.c b/src/libstddjb/buffer_getv.c index 280a3b4..ab637a3 100644 --- a/src/libstddjb/buffer_getv.c +++ b/src/libstddjb/buffer_getv.c @@ -1,6 +1,7 @@ /* ISC license. */ -#include +#include + #include #include @@ -8,5 +9,5 @@ ssize_t buffer_getv (buffer *b, struct iovec const *v, unsigned int n) { size_t w = 0 ; ssize_t r = unsanitize_read(buffer_getvall(b, v, n, &w)) ; - return r <= 0 ? r : w ; + return r < 0 ? r : w ; } diff --git a/src/libstddjb/slurpn.c b/src/libstddjb/slurpn.c index c9c5c11..ee5157f 100644 --- a/src/libstddjb/slurpn.c +++ b/src/libstddjb/slurpn.c @@ -16,7 +16,7 @@ int slurpn (int fd, stralloc *sa, size_t max) for (;;) { ssize_t r ; - size_t n = max && sa->len + N > max ? max - sa->len : N ; + size_t n = max && sa->len - sabase + N > max ? max - (sa->len - sabase) : N ; if (!n) { errno = ENOBUFS ; goto err ; } if (!stralloc_readyplus(sa, n)) break ; r = fd_read(fd, sa->s + sa->len, n) ; -- cgit v1.2.3