Mercurial > ~dholland > hg > ag > index.cgi
view help2html/buffer.c @ 15:f5acaf0c8a29
Don't cast through "volatile int". Causes a gcc warning nowadays.
XXX: should put something else back here to frighten the optimizer
author | David A. Holland |
---|---|
date | Tue, 31 May 2022 01:00:55 -0400 |
parents | 13d2b8934445 |
children |
line wrap: on
line source
#include <stdlib.h> #include <string.h> #include <assert.h> #include "must.h" #include "buffer.h" static void buffer_provide(struct buffer *b, size_t needed) { if (needed <= b->allocsize) { return; } size_t newalloc = b->allocsize*2; if (newalloc < 16) { newalloc = 16; } while (newalloc < needed) { newalloc *= 2; } b->text = must_realloc(b->text, newalloc); b->allocsize = newalloc; } void buffer_clear(struct buffer *b) { b->len = 0; b->text[b->len] = 0; } void buffer_init(struct buffer *b) { b->allocsize = 16; b->text = must_malloc(b->allocsize); buffer_clear(b); } void buffer_cleanup(struct buffer *b) { free(b->text); b->text = NULL; b->len = 0; b->allocsize = 0; } void buffer_append(struct buffer *b, const char *t) { size_t tlen = strlen(t); buffer_provide(b, b->len + tlen + 1); strcpy(b->text + b->len, t); b->len += tlen; } void buffer_add(struct buffer *b, int ch) { buffer_provide(b, b->len + 2); b->text[b->len++] = ch; b->text[b->len] = 0; } void buffer_start(struct buffer *b, int ch) { buffer_clear(b); buffer_add(b, ch); }