X-Git-Url: http://git.madism.org/?p=apps%2Fmadmutt.git;a=blobdiff_plain;f=lib-lib%2Fbuffer.c;h=f27dc5102d381aec71aa2a6c24da49afd6294bb4;hp=25f930dddaa4b6af97998b0f004805ed96616402;hb=a72bbb26973d73ce98c1dde62f3a114e2bb6589c;hpb=7489084cbae92559260659c8606eea91d70e8f3b diff --git a/lib-lib/buffer.c b/lib-lib/buffer.c index 25f930d..f27dc51 100644 --- a/lib-lib/buffer.c +++ b/lib-lib/buffer.c @@ -28,20 +28,48 @@ #include "lib-lib.h" -#define BUFSIZ_INCREMENT 1024 - -void buffer_resize(buffer_t *buf, ssize_t newsize) +void buffer_splice(buffer_t *buf, ssize_t pos, ssize_t len, + const void *data, ssize_t dlen) { - if (newsize >= buf->size) { - /* rounds newsize to the 1024 multiple just after newsize+1 */ - newsize = (newsize + BUFSIZ_INCREMENT) & ~(BUFSIZ_INCREMENT - 1); - p_realloc(&buf->data, newsize); - } + if (dlen >= len) + buffer_extend(buf, dlen - len); + memmove(buf->data + pos + dlen, + buf->data + pos + len, + buf->len - pos - len); + memcpy(buf->data + pos, data, dlen); + buffer_setlen(buf, buf->len + dlen - len); } +ssize_t buffer_addvf(buffer_t *buf, const char *fmt, va_list args) +{ + ssize_t len; + va_list ap; + va_copy(ap, args); + buffer_ensure(buf, BUFSIZ); + + len = vsnprintf(buf->data + buf->len, buf->size - buf->len, fmt, args); + if (len < 0) + return len; + if (len >= buf->size - buf->len) { + buffer_ensure(buf, len); + vsnprintf(buf->data + buf->len, buf->size - buf->len, fmt, ap); + } + buf->len += len; + buf->data[buf->len] = '\0'; + return len; +} +ssize_t buffer_addf(buffer_t *buf, const char *fmt, ...) +{ + ssize_t res; + va_list args; + va_start(args, fmt); + res = buffer_addvf(buf, fmt, args); + va_end(args); + return res; +} /****** LEGACY BUFFERS *******/ /* @@ -107,33 +135,3 @@ void mutt_buffer_add(BUFFER *buf, const char *s, ssize_t len) *buf->dptr = '\0'; } -ssize_t buffer_addvf(buffer_t *buf, const char *fmt, va_list args) -{ - ssize_t len; - va_list ap; - - va_copy(ap, args); - buffer_ensure(buf, BUFSIZ); - - len = vsnprintf(buf->data + buf->len, buf->size - buf->len, fmt, args); - if (len < 0) - return len; - if (len >= buf->size - buf->len) { - buffer_ensure(buf, len); - vsnprintf(buf->data + buf->len, buf->size - buf->len, fmt, ap); - } - buf->len += len; - buf->data[buf->len] = '\0'; - - return len; -} - -ssize_t buffer_addf(buffer_t *buf, const char *fmt, ...) -{ - ssize_t res; - va_list args; - va_start(args, fmt); - res = buffer_addvf(buf, fmt, args); - va_end(args); - return res; -}