aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@openbsd.org>2017-05-01 20:54:59 +0000
committerIngo Schwarze <schwarze@openbsd.org>2017-05-01 20:54:59 +0000
commit69dd502a67e421fe48f76ba10e1a259c9969b747 (patch)
treea826e0e495a03aa9020cb8c8a81e71661d995a4c
parent45a0a327d5183355d3878057425e8aa9935d70db (diff)
downloadmandoc-69dd502a67e421fe48f76ba10e1a259c9969b747.tar.gz
mandoc-69dd502a67e421fe48f76ba10e1a259c9969b747.tar.zst
mandoc-69dd502a67e421fe48f76ba10e1a259c9969b747.zip
When trying to expand some columns in a table where the sum of the
widths of the remaining columns is already wider than the line length, underflowing size_t and dying from ENOMEM is the wrong plan. Instead, simply refrain from expanding anything in such a situation, avoiding a crash that tb@ found with afl.
-rw-r--r--out.c9
-rw-r--r--regress/tbl/mod/Makefile2
-rw-r--r--regress/tbl/mod/expand-toowide.in15
-rw-r--r--regress/tbl/mod/expand-toowide.out_ascii23
4 files changed, 45 insertions, 4 deletions
diff --git a/out.c b/out.c
index aff35583..22cdfbba 100644
--- a/out.c
+++ b/out.c
@@ -1,7 +1,7 @@
-/* $Id: out.c,v 1.62 2015/10/12 00:08:16 schwarze Exp $ */
+/* $Id: out.c,v 1.63 2017/05/01 20:54:59 schwarze Exp $ */
/*
* Copyright (c) 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
- * Copyright (c) 2011, 2014, 2015 Ingo Schwarze <schwarze@openbsd.org>
+ * Copyright (c) 2011, 2014, 2015, 2017 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
@@ -197,9 +197,12 @@ tblcalc(struct rofftbl *tbl, const struct tbl_span *sp,
*/
if (nxcol && totalwidth) {
- xwidth = totalwidth - xwidth - 3*maxcol -
+ xwidth += 3*maxcol +
(opts->opts & (TBL_OPT_BOX | TBL_OPT_DBOX) ?
2 : !!opts->lvert + !!opts->rvert);
+ if (xwidth >= totalwidth)
+ return;
+ xwidth = totalwidth - xwidth;
/*
* Emulate a bug in GNU tbl width calculation that
diff --git a/regress/tbl/mod/Makefile b/regress/tbl/mod/Makefile
index c5bebb0f..04eec17e 100644
--- a/regress/tbl/mod/Makefile
+++ b/regress/tbl/mod/Makefile
@@ -1,6 +1,6 @@
# $OpenBSD: Makefile,v 1.2 2015/02/10 11:02:19 schwarze Exp $
-REGRESS_TARGETS = badfont expand font misalign
+REGRESS_TARGETS = badfont expand expand-toowide font misalign
LINT_TARGETS = badfont font
# groff-1.22.3 defects:
diff --git a/regress/tbl/mod/expand-toowide.in b/regress/tbl/mod/expand-toowide.in
new file mode 100644
index 00000000..7e8a44b8
--- /dev/null
+++ b/regress/tbl/mod/expand-toowide.in
@@ -0,0 +1,15 @@
+.TH TBL-MOD-EXPAND-TOOWIDE 1 "May 1, 2017" OpenBSD
+.SH NAME
+tbl-mod-expand-toowide \- try to expand columns in a table
+that is already too wide
+.SH DESCRIPTION
+.ll 20n
+In this section, the line length is limited to 20 characters.
+.TS
+tab(:);
+lx l lx.
+x:1234567890:x
+.TE
+.ll 78n
+.PP
+Now we are back to the default terminal width.
diff --git a/regress/tbl/mod/expand-toowide.out_ascii b/regress/tbl/mod/expand-toowide.out_ascii
new file mode 100644
index 00000000..066fdf90
--- /dev/null
+++ b/regress/tbl/mod/expand-toowide.out_ascii
@@ -0,0 +1,23 @@
+TBL-MOD-EXPAND-TOOWIDE(1) General Commands Manual TBL-MOD-EXPAND-TOOWIDE(1)
+
+
+
+NNAAMMEE
+ tbl-mod-expand-toowide - try to expand columns in a table that is
+ already too wide
+
+DDEESSCCRRIIPPTTIIOONN
+ In this
+ section, the
+ line length
+ is limited to
+ 20
+ characters.
+
+ x 1234567890 x
+
+ Now we are back to the default terminal width.
+
+
+
+OpenBSD May 1, 2017 TBL-MOD-EXPAND-TOOWIDE(1)