|
@@ -14,20 +14,25 @@ buf_init(struct io_buffer *iob, size_t size) |
|
|
{ |
|
|
{ |
|
|
iob->buf_off = 0; |
|
|
iob->buf_off = 0; |
|
|
iob->buf_len = size; |
|
|
iob->buf_len = size; |
|
|
|
|
|
iob->error = 0; |
|
|
iob->buf = malloc(size); |
|
|
iob->buf = malloc(size); |
|
|
if (iob->buf == NULL) |
|
|
if (iob->buf == NULL) { |
|
|
|
|
|
iob->error = ENOMEM; |
|
|
return ENOMEM; |
|
|
return ENOMEM; |
|
|
else |
|
|
} else |
|
|
return 0; |
|
|
return 0; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
int |
|
|
int |
|
|
buf_grow(struct io_buffer *iob, size_t addlen) |
|
|
buf_grow(struct io_buffer *iob, size_t addlen) |
|
|
{ |
|
|
{ |
|
|
|
|
|
if (iob->error) |
|
|
|
|
|
return iob->error; |
|
|
char *nbuf = realloc(iob->buf, iob->buf_len + addlen); |
|
|
char *nbuf = realloc(iob->buf, iob->buf_len + addlen); |
|
|
if (nbuf == NULL) |
|
|
if (nbuf == NULL) { |
|
|
|
|
|
iob->error = ENOMEM; |
|
|
return ENOMEM; |
|
|
return ENOMEM; |
|
|
else { |
|
|
} else { |
|
|
iob->buf = nbuf; |
|
|
iob->buf = nbuf; |
|
|
iob->buf_len += addlen; |
|
|
iob->buf_len += addlen; |
|
|
return 0; |
|
|
return 0; |
|
@@ -37,13 +42,15 @@ buf_grow(struct io_buffer *iob, size_t addlen) |
|
|
int |
|
|
int |
|
|
buf_print(struct io_buffer *iob, const char *fmt, ...) |
|
|
buf_print(struct io_buffer *iob, const char *fmt, ...) |
|
|
{ |
|
|
{ |
|
|
|
|
|
if (iob->error) |
|
|
|
|
|
return iob->error; |
|
|
int np; |
|
|
int np; |
|
|
va_list ap; |
|
|
va_list ap; |
|
|
va_start(ap, fmt); |
|
|
va_start(ap, fmt); |
|
|
np = vsnprintf(NULL, 0, fmt, ap); |
|
|
np = vsnprintf(NULL, 0, fmt, ap); |
|
|
va_end(ap); |
|
|
va_end(ap); |
|
|
while (np + 1 > iob->buf_len - iob->buf_off) |
|
|
if (np + 1 > iob->buf_len - iob->buf_off) |
|
|
if (buf_grow(iob, GROWLEN) != 0) |
|
|
if (buf_grow(iob, (1 + (np + 1) / GROWLEN) * GROWLEN) != 0) |
|
|
return ENOMEM; |
|
|
return ENOMEM; |
|
|
va_start(ap, fmt); |
|
|
va_start(ap, fmt); |
|
|
vsnprintf(iob->buf + iob->buf_off, np + 1, fmt, ap); |
|
|
vsnprintf(iob->buf + iob->buf_off, np + 1, fmt, ap); |
|
@@ -55,8 +62,10 @@ buf_print(struct io_buffer *iob, const char *fmt, ...) |
|
|
int |
|
|
int |
|
|
buf_write(struct io_buffer *iob, const void *buf, size_t len) |
|
|
buf_write(struct io_buffer *iob, const void *buf, size_t len) |
|
|
{ |
|
|
{ |
|
|
while (iob->buf_len - iob->buf_off < len) |
|
|
if (iob->error) |
|
|
if (buf_grow(iob, GROWLEN) != 0) |
|
|
return iob->error; |
|
|
|
|
|
if (len > iob->buf_len - iob->buf_off) |
|
|
|
|
|
if (buf_grow(iob, (1 + len / GROWLEN) * GROWLEN) != 0) |
|
|
return ENOMEM; |
|
|
return ENOMEM; |
|
|
bcopy(buf, iob->buf + iob->buf_off, len); |
|
|
bcopy(buf, iob->buf + iob->buf_off, len); |
|
|
iob->buf_off += len; |
|
|
iob->buf_off += len; |
|
|