=================================================================== RCS file: /cvs/mandoc/term_tab.c,v retrieving revision 1.3 retrieving revision 1.7 diff -u -p -r1.3 -r1.7 --- mandoc/term_tab.c 2017/06/14 17:51:15 1.3 +++ mandoc/term_tab.c 2021/10/04 18:56:31 1.7 @@ -1,6 +1,6 @@ -/* $OpenBSD: term_tab.c,v 1.3 2017/06/14 17:51:15 schwarze Exp $ */ +/* $Id: term_tab.c,v 1.7 2021/10/04 18:56:31 schwarze Exp $ */ /* - * Copyright (c) 2017 Ingo Schwarze + * Copyright (c) 2017, 2021 Ingo Schwarze * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above @@ -14,9 +14,13 @@ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ +#include "config.h" + #include #include +#include +#include #include "mandoc_aux.h" #include "out.h" @@ -31,6 +35,7 @@ struct tablist { static struct { struct tablist a; /* All tab positions for lookup. */ struct tablist p; /* Periodic tab positions to add. */ + struct tablist *r; /* Tablist currently being recorded. */ size_t d; /* Default tab width in units of n. */ } tabs; @@ -38,8 +43,6 @@ static struct { void term_tab_set(const struct termp *p, const char *arg) { - static int recording_period; - struct roffsu su; struct tablist *tl; size_t pos; @@ -49,7 +52,7 @@ term_tab_set(const struct termp *p, const char *arg) if (arg == NULL) { tabs.a.n = tabs.p.n = 0; - recording_period = 0; + tabs.r = &tabs.a; if (tabs.d == 0) { a2roffsu(".8i", &su, SCALE_IN); tabs.d = term_hen(p, &su); @@ -57,7 +60,7 @@ term_tab_set(const struct termp *p, const char *arg) return; } if (arg[0] == 'T' && arg[1] == '\0') { - recording_period = 1; + tabs.r = &tabs.p; return; } @@ -73,7 +76,7 @@ term_tab_set(const struct termp *p, const char *arg) /* Select the list, and extend it if it is full. */ - tl = recording_period ? &tabs.p : &tabs.a; + tl = tabs.r; if (tl->n >= tl->s) { tl->s += 8; tl->t = mandoc_reallocarray(tl->t, tl->s, sizeof(*tl->t)); @@ -88,6 +91,21 @@ term_tab_set(const struct termp *p, const char *arg) tl->n++; } +/* + * Simplified version without a parser, + * never incremental, never periodic, for use by tbl(7). + */ +void +term_tab_iset(size_t inc) +{ + if (tabs.a.n >= tabs.a.s) { + tabs.a.s += 8; + tabs.a.t = mandoc_reallocarray(tabs.a.t, tabs.a.s, + sizeof(*tabs.a.t)); + } + tabs.a.t[tabs.a.n++] = inc; +} + size_t term_tab_next(size_t prev) { @@ -110,4 +128,13 @@ term_tab_next(size_t prev) if (prev < tabs.a.t[i]) return tabs.a.t[i]; } +} + +void +term_tab_free(void) +{ + free(tabs.a.t); + free(tabs.p.t); + memset(&tabs, 0, sizeof(tabs)); + tabs.r = &tabs.a; }