From 71f232282a6bb3a45bd020e3681ac0dd90371c63 Mon Sep 17 00:00:00 2001 From: "Chloe M." Date: Sat, 23 May 2026 19:01:51 -0400 Subject: core: tokbuf: Fix up token buffer Signed-off-by: Chloe M. --- core/tokbuf.c | 37 +++++++++++++++++++++++++++---------- include/cescal/tokbuf.h | 10 ++++++++++ 2 files changed, 37 insertions(+), 10 deletions(-) diff --git a/core/tokbuf.c b/core/tokbuf.c index 6df5686..1c9783f 100644 --- a/core/tokbuf.c +++ b/core/tokbuf.c @@ -29,26 +29,48 @@ tokbuf_init(struct tokbuf *tokbuf) return 0; } +#include + int tokbuf_push(struct tokbuf *tokbuf, struct token *tok) { void *p; + size_t newcap; if (tokbuf == NULL || tok == NULL) { return -1; } - if ((tokbuf->head++) >= tokbuf->cap - 1) { - tokbuf->cap += 8; - p = realloc(tokbuf->buf, sizeof(struct token) * tokbuf->cap); - if (tokbuf->buf == NULL) { + if (tokbuf->head >= tokbuf->cap) { + newcap = tokbuf->cap * 8; + p = realloc(tokbuf->buf, sizeof(struct token) * newcap); + if (p == NULL) { return -1; } tokbuf->buf = p; + tokbuf->cap = newcap; + } + + printf("%d %d\n", tokbuf->head, tok->type); + tokbuf->buf[tokbuf->head++] = *tok; + return 0; +} + +int +tokbuf_pop(struct tokbuf *tokbuf, struct token *res) +{ + if (tokbuf == NULL || res == NULL) { + errno = EINVAL; + return -1; + } + + if (tokbuf->head >= 0) { + errno = EAGAIN; + return -1; } - tokbuf->buf[tokbuf->head] = *tok; + *res = tokbuf->buf[tokbuf->head--]; return 0; } @@ -62,11 +84,6 @@ tokbuf_noff(struct tokbuf *tokbuf, size_t noff, struct token *res) return -1; } - if (noff == 0) { - *res = tokbuf->buf[tokbuf->head + 1]; - return 0; - } - if ((off = (tokbuf->head - noff + 1)) < 0) { off = 0; } diff --git a/include/cescal/tokbuf.h b/include/cescal/tokbuf.h index 61b80a3..dd1a2ab 100644 --- a/include/cescal/tokbuf.h +++ b/include/cescal/tokbuf.h @@ -37,6 +37,16 @@ int tokbuf_init(struct tokbuf *tokbuf); */ int tokbuf_push(struct tokbuf *tokbuf, struct token *tok); +/* + * Pop a token from the token buffer + * + * @tokbuf: Token buffer to pop from + * @res: Result is written here + * + * Returns zero on success + */ +int tokbuf_pop(struct tokbuf *tokbuf, struct token *res); + /* * Peek at the token buffer from a negative offset backwards * -- cgit v1.2.3