More buffer functions.
[apps/madmutt.git] / lib-lib / buffer.c
index 71f31b4..f27dc51 100644 (file)
 
 #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) {
-        len = 0;
-    }
-    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;
-}