]> git.cameronkatri.com Git - mandoc.git/blobdiff - out.c
Revert part of the previous diff to fix a regression (another endless loop)
[mandoc.git] / out.c
diff --git a/out.c b/out.c
index d0b0d0a2ace3c1c86ef330e2456660e7ef985b78..797a252abfeb6748d50d2ef23b97e33f4fbada55 100644 (file)
--- a/out.c
+++ b/out.c
@@ -1,7 +1,8 @@
-/*     $Id: out.c,v 1.78 2019/03/29 21:27:06 schwarze Exp $ */
+/*     $Id: out.c,v 1.83 2021/09/28 17:06:59 schwarze Exp $ */
 /*
  * Copyright (c) 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
- * Copyright (c) 2011,2014,2015,2017,2018 Ingo Schwarze <schwarze@openbsd.org>
+ * Copyright (c) 2011, 2014, 2015, 2017, 2018, 2019, 2021
+ *               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
 #include <assert.h>
 #include <ctype.h>
 #include <stdint.h>
+#include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
 #include <time.h>
 
 #include "mandoc_aux.h"
+#include "mandoc.h"
 #include "tbl.h"
 #include "out.h"
 
@@ -209,13 +212,25 @@ tblcalc(struct rofftbl *tbl, const struct tbl_span *sp_first,
        }
 
        /*
-        * Column spacings are needed for span width calculations,
-        * so set the default values now.
+        * The minimum width of columns explicitly specified
+        * in the layout is 1n.
         */
 
-       for (icol = 0; icol <= maxcol; icol++)
-               if (tbl->cols[icol].spacing == SIZE_MAX || icol == maxcol)
-                       tbl->cols[icol].spacing = 3;
+       if (maxcol < sp_first->opts->cols - 1)
+               maxcol = sp_first->opts->cols - 1;
+       for (icol = 0; icol <= maxcol; icol++) {
+               col = tbl->cols + icol;
+               if (col->width < 1)
+                       col->width = 1;
+
+               /*
+                * Column spacings are needed for span width
+                * calculations, so set the default values now.
+                */
+
+               if (col->spacing == SIZE_MAX || icol == maxcol)
+                       col->spacing = 3;
+       }
 
        /*
         * Replace the minimum widths with the missing widths,
@@ -263,12 +278,12 @@ tblcalc(struct rofftbl *tbl, const struct tbl_span *sp_first,
 
                min1 = min2 = SIZE_MAX;
                for (icol = 0; icol <= maxcol; icol++) {
-                       if (min1 > colwidth[icol]) {
+                       width = colwidth[icol];
+                       if (min1 > width) {
                                min2 = min1;
-                               min1 = colwidth[icol];
-                       } else if (min1 < colwidth[icol] &&
-                           min2 > colwidth[icol])
-                               min2 = colwidth[icol];
+                               min1 = width;
+                       } else if (min1 < width && min2 > width)
+                               min2 = width;
                }
 
                /*
@@ -281,7 +296,7 @@ tblcalc(struct rofftbl *tbl, const struct tbl_span *sp_first,
                for (g = first_group; g != NULL; g = g->next) {
                        necol = 0;
                        for (icol = g->startcol; icol <= g->endcol; icol++)
-                               if (tbl->cols[icol].width == min1)
+                               if (colwidth[icol] == min1)
                                        necol++;
                        if (necol == 0)
                                continue;
@@ -290,26 +305,22 @@ tblcalc(struct rofftbl *tbl, const struct tbl_span *sp_first,
                                width = min2;
                        if (wanted > width)
                                wanted = width;
-                       for (icol = g->startcol; icol <= g->endcol; icol++)
-                               if (colwidth[icol] == min1 ||
-                                   (colwidth[icol] < min2 &&
-                                    colwidth[icol] > width))
-                                       colwidth[icol] = width;
                }
 
-               /* Record the effect of the widening on the group list. */
+               /* Record the effect of the widening. */
 
                gp = &first_group;
                while ((g = *gp) != NULL) {
                        done = 0;
                        for (icol = g->startcol; icol <= g->endcol; icol++) {
-                               if (colwidth[icol] != wanted ||
-                                   tbl->cols[icol].width == wanted)
+                               if (colwidth[icol] != min1)
                                        continue;
                                if (g->wanted <= wanted - min1) {
+                                       tbl->cols[icol].width += g->wanted;
                                        done = 1;
                                        break;
                                }
+                               tbl->cols[icol].width = wanted;
                                g->wanted -= wanted - min1;
                        }
                        if (done) {
@@ -318,12 +329,6 @@ tblcalc(struct rofftbl *tbl, const struct tbl_span *sp_first,
                        } else
                                gp = &(*gp)->next;
                }
-
-               /* Record the effect of the widening on the columns. */
-
-               for (icol = 0; icol <= maxcol; icol++)
-                       if (colwidth[icol] == wanted)
-                               tbl->cols[icol].width = wanted;
        }
        free(colwidth);
 
@@ -340,8 +345,6 @@ tblcalc(struct rofftbl *tbl, const struct tbl_span *sp_first,
                col = tbl->cols + icol;
                if (col->width > col->nwidth)
                        col->decimal += (col->width - col->nwidth) / 2;
-               else
-                       col->width = col->nwidth;
                if (col->flags & TBL_CELL_EQUAL) {
                        necol++;
                        if (ewidth < col->width)
@@ -549,5 +552,7 @@ tblcalc_number(struct rofftbl *tbl, struct roffcol *col,
 
        if (totsz > col->nwidth)
                col->nwidth = totsz;
+       if (col->nwidth > col->width)
+               col->width = col->nwidth;
        return totsz;
 }