=================================================================== RCS file: /cvs/mandoc/out.c,v retrieving revision 1.78 retrieving revision 1.81 diff -u -p -r1.78 -r1.81 --- mandoc/out.c 2019/03/29 21:27:06 1.78 +++ mandoc/out.c 2021/09/07 14:56:35 1.81 @@ -1,7 +1,8 @@ -/* $Id: out.c,v 1.78 2019/03/29 21:27:06 schwarze Exp $ */ +/* $Id: out.c,v 1.81 2021/09/07 14:56:35 schwarze Exp $ */ /* * Copyright (c) 2009, 2010, 2011 Kristaps Dzonsons - * Copyright (c) 2011,2014,2015,2017,2018 Ingo Schwarze + * Copyright (c) 2011, 2014, 2015, 2017, 2018, 2019, 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 @@ -22,11 +23,13 @@ #include #include #include +#include #include #include #include #include "mandoc_aux.h" +#include "mandoc.h" #include "tbl.h" #include "out.h" @@ -209,14 +212,26 @@ tblcalc(struct rofftbl *tbl, const struct tbl_span *sp } /* - * 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, * and dismiss groups that are already wide enough. @@ -340,8 +355,6 @@ tblcalc(struct rofftbl *tbl, const struct tbl_span *sp 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 +562,7 @@ tblcalc_number(struct rofftbl *tbl, struct roffcol *co if (totsz > col->nwidth) col->nwidth = totsz; + if (col->nwidth > col->width) + col->width = col->nwidth; return totsz; }