]> git.cameronkatri.com Git - mandoc.git/blobdiff - term.c
Make sure that the configuration file is always read, even when
[mandoc.git] / term.c
diff --git a/term.c b/term.c
index 3b9277aaabbc371105c39dbc0e521e2b181bd102..f4adf9522a4f5edf166a3a855a31ed8e6f005ff4 100644 (file)
--- a/term.c
+++ b/term.c
@@ -1,7 +1,7 @@
-/*     $Id: term.c,v 1.281 2019/06/03 20:23:41 schwarze Exp $ */
+/* $Id: term.c,v 1.284 2021/10/04 18:56:31 schwarze Exp $ */
 /*
+ * Copyright (c) 2010-2021 Ingo Schwarze <schwarze@openbsd.org>
  * Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
- * Copyright (c) 2010-2019 Ingo Schwarze <schwarze@openbsd.org>
  *
  * Permission to use, copy, modify, and distribute this software for any
  * purpose with or without fee is hereby granted, provided that the above
@@ -38,8 +38,7 @@ static        void             bufferc(struct termp *, char);
 static void             encode(struct termp *, const char *, size_t);
 static void             encode1(struct termp *, int);
 static void             endline(struct termp *);
-static void             term_field(struct termp *, size_t, size_t,
-                               size_t, size_t);
+static void             term_field(struct termp *, size_t, size_t);
 static void             term_fill(struct termp *, size_t *, size_t *,
                                size_t);
 
@@ -59,6 +58,7 @@ term_setcol(struct termp *p, size_t maxtcol)
 void
 term_free(struct termp *p)
 {
+       term_tab_free();
        for (p->tcol = p->tcols; p->tcol < p->tcols + p->maxtcol; p->tcol++)
                free(p->tcol->buf);
        free(p->tcols);
@@ -127,8 +127,7 @@ term_flushln(struct termp *p)
                 * and with the BRNEVER flag, never break it at all.
                 */
 
-               vtarget = p->flags & TERMP_BRNEVER ? SIZE_MAX :
-                   (p->flags & TERMP_NOBREAK) == 0 ? vfield :
+               vtarget = (p->flags & TERMP_NOBREAK) == 0 ? vfield :
                    p->maxrmargin > p->viscol + vbl ?
                    p->maxrmargin - p->viscol - vbl : 0;
 
@@ -137,7 +136,8 @@ term_flushln(struct termp *p)
                 * If there is whitespace only, print nothing.
                 */
 
-               term_fill(p, &nbr, &vbr, vtarget);
+               term_fill(p, &nbr, &vbr,
+                   p->flags & TERMP_BRNEVER ? SIZE_MAX : vtarget);
                if (nbr == 0)
                        break;
 
@@ -156,7 +156,7 @@ term_flushln(struct termp *p)
 
                /* Finally, print the field content. */
 
-               term_field(p, vbl, nbr, vbr, vtarget);
+               term_field(p, vbl, nbr);
 
                /*
                 * If there is no text left in the field, exit the loop.
@@ -345,12 +345,10 @@ term_fill(struct termp *p, size_t *nbr, size_t *vbr, size_t vtarget)
 /*
  * Print the contents of one field
  * with an indentation of       vbl      visual columns,
- * an input string length of    nbr      characters,
- * an output width of           vbr      visual columns,
- * and a desired field width of         vtarget  visual columns.
+ * and an input string length of nbr     characters.
  */
 static void
-term_field(struct termp *p, size_t vbl, size_t nbr, size_t vbr, size_t vtarget)
+term_field(struct termp *p, size_t vbl, size_t nbr)
 {
        size_t   ic;    /* Character position in the input buffer. */
        size_t   vis;   /* Visual position of the current character. */
@@ -592,16 +590,18 @@ term_word(struct termp *p, const char *word)
                        uc = *seq;
                        break;
                case ESCAPE_FONTBOLD:
+               case ESCAPE_FONTCB:
                        term_fontrepl(p, TERMFONT_BOLD);
                        continue;
                case ESCAPE_FONTITALIC:
+               case ESCAPE_FONTCI:
                        term_fontrepl(p, TERMFONT_UNDER);
                        continue;
                case ESCAPE_FONTBI:
                        term_fontrepl(p, TERMFONT_BI);
                        continue;
                case ESCAPE_FONT:
-               case ESCAPE_FONTCW:
+               case ESCAPE_FONTCR:
                case ESCAPE_FONTROMAN:
                        term_fontrepl(p, TERMFONT_NONE);
                        continue;