]> git.cameronkatri.com Git - mandoc.git/commitdiff
Implement spacing of columns as defined in the table layout;
authorIngo Schwarze <schwarze@openbsd.org>
Tue, 27 Jun 2017 18:25:02 +0000 (18:25 +0000)
committerIngo Schwarze <schwarze@openbsd.org>
Tue, 27 Jun 2017 18:25:02 +0000 (18:25 +0000)
this is for example used by lftp(1)
and, ironically, misused by our very own tbl(7) manual...

out.c
out.h
tbl_layout.c
tbl_term.c

diff --git a/out.c b/out.c
index 5fd15343968466f78f1fe45bda4f82ef9cc238f1..b2b643787ec1f401cacb944f839bf9ac44056ec0 100644 (file)
--- a/out.c
+++ b/out.c
@@ -1,4 +1,4 @@
-/*     $Id: out.c,v 1.69 2017/06/15 00:27:52 schwarze Exp $ */
+/*     $Id: out.c,v 1.70 2017/06/27 18:25:02 schwarze Exp $ */
 /*
  * Copyright (c) 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2011, 2014, 2015, 2017 Ingo Schwarze <schwarze@openbsd.org>
@@ -20,6 +20,7 @@
 #include <sys/types.h>
 
 #include <assert.h>
+#include <stdint.h>
 #include <stdlib.h>
 #include <string.h>
 #include <time.h>
@@ -140,8 +141,8 @@ tblcalc(struct rofftbl *tbl, const struct tbl_span *sp,
                        if (1 < spans)
                                continue;
                        icol = dp->layout->col;
-                       if (maxcol < icol)
-                               maxcol = icol;
+                       while (maxcol < icol)
+                               tbl->cols[++maxcol].spacing = SIZE_MAX;
                        col = tbl->cols + icol;
                        col->flags |= dp->layout->flags;
                        if (dp->layout->flags & TBL_CELL_WIGN)
@@ -154,6 +155,10 @@ tblcalc(struct rofftbl *tbl, const struct tbl_span *sp,
                                    (*tbl->sulen)(&su, tbl->arg);
                        if (col->width < dp->layout->width)
                                col->width = dp->layout->width;
+                       if (dp->layout->spacing != SIZE_MAX &&
+                           (col->spacing == SIZE_MAX ||
+                            col->spacing < dp->layout->spacing))
+                               col->spacing = dp->layout->spacing;
                        tblcalc_data(tbl, col, opts, dp,
                            dp->block == 0 ? 0 :
                            dp->layout->width ? dp->layout->width :
@@ -172,6 +177,8 @@ tblcalc(struct rofftbl *tbl, const struct tbl_span *sp,
        ewidth = xwidth = 0;
        for (icol = 0; icol <= maxcol; icol++) {
                col = tbl->cols + icol;
+               if (col->spacing == SIZE_MAX || icol == maxcol)
+                       col->spacing = 3;
                if (col->flags & TBL_CELL_EQUAL) {
                        necol++;
                        if (ewidth < col->width)
diff --git a/out.h b/out.h
index 94040035d6aea09aa5c3596013d63d88d75b1b40..f6aceb9c13f4d7b814ab413a027a63eea5f30322 100644 (file)
--- a/out.h
+++ b/out.h
@@ -1,4 +1,4 @@
-/*     $Id: out.h,v 1.30 2017/06/12 20:14:18 schwarze Exp $ */
+/*     $Id: out.h,v 1.31 2017/06/27 18:25:02 schwarze Exp $ */
 /*
  * Copyright (c) 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2014, 2017 Ingo Schwarze <schwarze@openbsd.org>
@@ -33,6 +33,7 @@ enum  roffscale {
 struct roffcol {
        size_t           width; /* width of cell */
        size_t           decimal; /* decimal position in cell */
+       size_t           spacing; /* spacing after the column */
        int              flags; /* layout flags, see tbl_cell */
 };
 
index 5357d80871690293c0aac70776e2160453c59b70..42fc0e8296f59cbef47e5f9cc78fd41837cd5a50 100644 (file)
@@ -1,4 +1,4 @@
-/*     $Id: tbl_layout.c,v 1.43 2017/06/13 16:12:01 schwarze Exp $ */
+/*     $Id: tbl_layout.c,v 1.44 2017/06/27 18:25:02 schwarze Exp $ */
 /*
  * Copyright (c) 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2012, 2014, 2015, 2017 Ingo Schwarze <schwarze@openbsd.org>
@@ -20,6 +20,7 @@
 #include <sys/types.h>
 
 #include <ctype.h>
+#include <stdint.h>
 #include <stdlib.h>
 #include <string.h>
 #include <time.h>
@@ -357,6 +358,7 @@ cell_alloc(struct tbl_node *tbl, struct tbl_row *rp, enum tbl_cellt pos)
        struct tbl_cell *p, *pp;
 
        p = mandoc_calloc(1, sizeof(*p));
+       p->spacing = SIZE_MAX;
        p->pos = pos;
 
        if ((pp = rp->last) != NULL) {
index 40342d2f2327344df808e594ff8fe463bd671da1..225fa317e54375c3f5e0c96e459eaefa275792a3 100644 (file)
@@ -1,4 +1,4 @@
-/*     $Id: tbl_term.c,v 1.54 2017/06/17 14:55:30 schwarze Exp $ */
+/*     $Id: tbl_term.c,v 1.55 2017/06/27 18:25:02 schwarze Exp $ */
 /*
  * Copyright (c) 2009, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2011,2012,2014,2015,2017 Ingo Schwarze <schwarze@openbsd.org>
@@ -101,7 +101,7 @@ term_tbl(struct termp *tp, const struct tbl_span *sp)
                for (ic = 0; ic < sp->opts->cols; ic++) {
                        coloff += tp->tbl.cols[ic].width;
                        term_tab_iset(coloff);
-                       coloff += 3;
+                       coloff += tp->tbl.cols[ic].spacing;
                }
 
                /* Center the table as a whole. */
@@ -110,9 +110,11 @@ term_tbl(struct termp *tp, const struct tbl_span *sp)
                if (sp->opts->opts & TBL_OPT_CENTRE) {
                        tsz = sp->opts->opts & (TBL_OPT_BOX | TBL_OPT_DBOX)
                            ? 2 : !!sp->opts->lvert + !!sp->opts->rvert;
-                       for (ic = 0; ic < sp->opts->cols; ic++)
-                               tsz += tp->tbl.cols[ic].width + 3;
-                       tsz -= 3;
+                       for (ic = 0; ic + 1 < sp->opts->cols; ic++)
+                               tsz += tp->tbl.cols[ic].width +
+                                   tp->tbl.cols[ic].spacing;
+                       if (sp->opts->cols)
+                               tsz += tp->tbl.cols[sp->opts->cols - 1].width;
                        if (offset + tsz > tp->tcol->rmargin)
                                tsz -= 1;
                        tp->tcol->offset = offset + tp->tcol->rmargin > tsz ?
@@ -159,9 +161,8 @@ term_tbl(struct termp *tp, const struct tbl_span *sp)
                        }
                        coloff += tp->tbl.cols[ic].width;
                        tp->tcol->rmargin = coloff;
-                       coloff++;
                        if (ic + 1 < sp->opts->cols)
-                               coloff += 2;
+                               coloff += tp->tbl.cols[ic].spacing;
                        if (spans) {
                                spans--;
                                continue;
@@ -175,7 +176,7 @@ term_tbl(struct termp *tp, const struct tbl_span *sp)
                /* Set up a column for a right vertical frame. */
 
                tp->tcol++;
-               tp->tcol->offset = coloff;
+               tp->tcol->offset = coloff + 1;
                tp->tcol->rmargin = tp->maxrmargin;
 
                /* Spans may have reduced the number of columns. */
@@ -327,13 +328,13 @@ term_tbl(struct termp *tp, const struct tbl_span *sp)
                                    tp->tcol + 1 == tp->tcols + tp->lasttcol))
                                        continue;
 
-                               if (tp->tcol->rmargin > tp->viscol) {
+                               if (tp->viscol < tp->tcol->rmargin) {
                                        (*tp->advance)(tp, tp->tcol->rmargin
                                           - tp->viscol);
                                        tp->viscol = tp->tcol->rmargin;
                                }
-
-                               if (tp->tcol->rmargin + 1 > tp->viscol) {
+                               while (tp->viscol < tp->tcol->rmargin +
+                                   tp->tbl.cols[ic].spacing / 2) {
                                        (*tp->letter)(tp, fc);
                                        tp->viscol++;
                                }
@@ -353,10 +354,11 @@ term_tbl(struct termp *tp, const struct tbl_span *sp)
                                                break;
                                        }
                                }
-
-                               (*tp->letter)(tp,
-                                   fc == ' ' ? '|' : vert ? '+' : fc);
-                               tp->viscol++;
+                               if (tp->tbl.cols[ic].spacing) {
+                                       (*tp->letter)(tp, fc == ' ' ? '|' :
+                                           vert ? '+' : fc);
+                                       tp->viscol++;
+                               }
 
                                if (fc != ' ') {
                                        if (cp != NULL &&
@@ -368,7 +370,8 @@ term_tbl(struct termp *tp, const struct tbl_span *sp)
                                        else
                                                fc = ' ';
                                }
-                               if (vert > 1 || fc != ' ') {
+                               if (tp->tbl.cols[ic].spacing > 2 &&
+                                   (vert > 1 || fc != ' ')) {
                                        (*tp->letter)(tp, fc == ' ' ? '|' :
                                            vert > 1 ? '+' : fc);
                                        tp->viscol++;
@@ -448,6 +451,7 @@ static void
 tbl_hrule(struct termp *tp, const struct tbl_span *sp, int kind)
 {
        const struct tbl_cell *cp, *cpn, *cpp;
+       const struct roffcol *col;
        int      vert;
        char     line, cross;
 
@@ -464,7 +468,8 @@ tbl_hrule(struct termp *tp, const struct tbl_span *sp, int kind)
        if (cpn == cp)
                cpn = NULL;
        for (;;) {
-               tbl_char(tp, line, tp->tbl.cols[cp->col].width + 1);
+               col = tp->tbl.cols + cp->col;
+               tbl_char(tp, line, col->width + col->spacing / 2);
                vert = cp->vert;
                if ((cp = cp->next) == NULL)
                         break;
@@ -480,10 +485,12 @@ tbl_hrule(struct termp *tp, const struct tbl_span *sp, int kind)
                }
                if (sp->opts->opts & TBL_OPT_ALLBOX && !vert)
                        vert = 1;
-               if (vert)
-                       tbl_char(tp, cross, vert);
-               if (vert < 2)
-                       tbl_char(tp, line, 2 - vert);
+               if (col->spacing)
+                       tbl_char(tp, vert ? cross : line, 1);
+               if (col->spacing > 2)
+                       tbl_char(tp, vert > 1 ? cross : line, 1);
+               if (col->spacing > 4)
+                       tbl_char(tp, line, (col->spacing - 3) / 2);
        }
        if (kind) {
                term_word(tp, "+");