Skip to content

Commit

Permalink
Make it safe to always use data as a character string
Browse files Browse the repository at this point in the history
  • Loading branch information
Cédric Deltheil committed Jan 8, 2013
1 parent c0804a1 commit 1f40bca
Showing 1 changed file with 4 additions and 4 deletions.
8 changes: 4 additions & 4 deletions buffer.c
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ buffer_new_with_size(size_t n) {
buffer_t *self = malloc(sizeof(buffer_t));
if (!self) return NULL;
self->len = n;
self->data = self->alloc = calloc(n, 1);
self->data = self->alloc = calloc(n + 1, 1);
return self;
}

Expand Down Expand Up @@ -88,7 +88,7 @@ ssize_t
buffer_compact(buffer_t *self) {
size_t len = buffer_length(self);
size_t rem = self->len - len;
char *buf = calloc(len, 1);
char *buf = calloc(len + 1, 1);
if (!buf) return -1;
memcpy(buf, self->data, len);
free(self->alloc);
Expand Down Expand Up @@ -133,7 +133,7 @@ int
buffer_resize(buffer_t *self, size_t n) {
n = nearest_multiple_of(1024, n);
self->len = n;
self->alloc = self->data = realloc(self->alloc, n);
self->alloc = self->data = realloc(self->alloc, n + 1);
return self->alloc ? 0 : -1;
}

Expand Down Expand Up @@ -205,7 +205,7 @@ buffer_slice(buffer_t *buf, size_t from, ssize_t to) {
if (to > len) to = len;

size_t n = to - from;
buffer_t *self = buffer_new_with_size(n + 1);
buffer_t *self = buffer_new_with_size(n);
memcpy(self->data, buf->data + from, n);
return self;
}
Expand Down

0 comments on commit 1f40bca

Please sign in to comment.