/******************************************************************************/
-/* postlicyd: a postfix policy daemon with a lot of features */
+/* pfixtools: a collection of postfix related tools */
/* ~~~~~~~~~ */
/* ________________________________________________________________________ */
/* */
/******************************************************************************/
/*
- * Copyright © 2006 Pierre Habouzit
+ * Copyright © 2006-2007 Pierre Habouzit
*/
+#include <errno.h>
#include <stdio.h>
#include <unistd.h>
+#include "mem.h"
#include "buffer.h"
#define BUFSIZ_INCREMENT 256
void buffer_resize(buffer_t *buf, ssize_t newsize)
{
- 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);
+ p_allocgrow(&buf->data, newsize + 1, &buf->size);
+}
+
+ssize_t buffer_addvf(buffer_t *buf, const char *fmt, va_list ap)
+{
+ ssize_t len, avail = buf->size - buf->len;
+ va_list ap2;
+
+ va_copy(ap2, ap);
+
+ len = vsnprintf(buf->data + buf->len, avail, fmt, ap);
+ if (len >= avail) {
+ buffer_resize(buf, buf->len + len);
+ avail = buf->size - buf->len;
+ len = vsnprintf(buf->data + buf->len, avail, fmt, ap2);
}
+ buf->len += len;
+ buf->data[buf->len] = '\0';
+ va_end(ap2);
+ return len;
}
-void buffer_consume(buffer_t *buf, ssize_t len) {
+void buffer_consume(buffer_t *buf, ssize_t len)
+{
if (len <= 0)
return;
buffer_extend(buf, res);
return res;
}
+
+ssize_t buffer_write(buffer_t *buf, int fd)
+{
+ ssize_t res = write(fd, buf->data, buf->len);
+ if (res < 0) {
+ return errno == EINTR || errno == EAGAIN ? 0 : -1;
+ }
+ buffer_consume(buf, res);
+ return res;
+}