aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@openbsd.org>2020-09-03 17:42:15 +0000
committerIngo Schwarze <schwarze@openbsd.org>2020-09-03 17:42:15 +0000
commitb71589000b1859d45cf1f2c247dc91fabf4f6753 (patch)
tree2347db946fe233c3d0305d3e47c76d8ac3af88b6
parent14be1f050f9c4f779e75454ecedfad4b1386ce0a (diff)
downloadmandoc-b71589000b1859d45cf1f2c247dc91fabf4f6753.tar.gz
mandoc-b71589000b1859d45cf1f2c247dc91fabf4f6753.tar.zst
mandoc-b71589000b1859d45cf1f2c247dc91fabf4f6753.zip
If .ti had an excessive argument, using it was attempted, in some
cases resulting in an assertion failure. Instead, truncate the temporary indent to a width reasonable in a manual page. I found the issue in an afl run that was performed by Jan Schreiber <jes at posteo dot de>.
-rw-r--r--regress/roff/ti/Makefile10
-rw-r--r--regress/roff/ti/wide.in19
-rw-r--r--regress/roff/ti/wide.out_ascii22
-rw-r--r--roff_term.c34
4 files changed, 71 insertions, 14 deletions
diff --git a/regress/roff/ti/Makefile b/regress/roff/ti/Makefile
index 4ac4cde0..aa0b1f97 100644
--- a/regress/roff/ti/Makefile
+++ b/regress/roff/ti/Makefile
@@ -1,5 +1,11 @@
-# $OpenBSD: Makefile,v 1.1 2017/05/07 17:30:58 schwarze Exp $
+# $OpenBSD: Makefile,v 1.2 2020/09/03 17:37:06 schwarze Exp $
-REGRESS_TARGETS = basic-mdoc basic-man
+REGRESS_TARGETS = basic-mdoc basic-man wide
+
+# groff-1.22.4 defect:
+# - Excessive temporare indentations cause excessive line lengths
+# instead of being truncated to resonable indentations.
+
+SKIP_GROFF = wide
.include <bsd.regress.mk>
diff --git a/regress/roff/ti/wide.in b/regress/roff/ti/wide.in
new file mode 100644
index 00000000..46a1f90b
--- /dev/null
+++ b/regress/roff/ti/wide.in
@@ -0,0 +1,19 @@
+.\" $OpenBSD: wide.in,v 1.1 2020/09/03 17:37:06 schwarze Exp $
+.TH TI-WIDE 1 "September 3, 2020"
+.SH NAME
+ti-wide \- excessive temporary indentation
+.SH DESCRIPTION
+Absolute .ti of more than 72n:
+.ti 80n
+max
+.RS 40n
+Indented block plus excessive relative indentation:
+.ti +40n
+max
+.RE
+.RS 66n
+Block beyond 72n:
+.ti +4n
+same
+.RE
+Back to normal.
diff --git a/regress/roff/ti/wide.out_ascii b/regress/roff/ti/wide.out_ascii
new file mode 100644
index 00000000..95a98ddc
--- /dev/null
+++ b/regress/roff/ti/wide.out_ascii
@@ -0,0 +1,22 @@
+TI-WIDE(1) General Commands Manual TI-WIDE(1)
+
+
+
+NNAAMMEE
+ ti-wide - excessive temporary indentation
+
+DDEESSCCRRIIPPTTIIOONN
+ Absolute .ti of more than 72n:
+ max
+ Indented block plus excessive
+ relative indentation:
+ max
+ Block
+ beyond
+ 72n:
+ same
+ Back to normal.
+
+
+
+OpenBSD September 3, 2020 TI-WIDE(1)
diff --git a/roff_term.c b/roff_term.c
index 9b251f49..ebfb75ef 100644
--- a/roff_term.c
+++ b/roff_term.c
@@ -1,4 +1,4 @@
-/* $Id: roff_term.c,v 1.20 2020/06/22 19:20:40 schwarze Exp $ */
+/* $Id: roff_term.c,v 1.21 2020/09/03 17:42:15 schwarze Exp $ */
/*
* Copyright (c) 2010,2014,2015,2017-2019 Ingo Schwarze <schwarze@openbsd.org>
*
@@ -210,6 +210,7 @@ roff_term_pre_ti(ROFF_TERM_ARGS)
{
struct roffsu su;
const char *cp;
+ const size_t maxoff = 72;
int len, sign;
roff_term_pre_br(p, n);
@@ -230,17 +231,26 @@ roff_term_pre_ti(ROFF_TERM_ARGS)
return;
len = term_hen(p, &su);
- if (sign == 0) {
+ switch (sign) {
+ case 1:
+ if (p->tcol->offset + len <= maxoff)
+ p->ti = len;
+ else if (p->tcol->offset < maxoff)
+ p->ti = maxoff - p->tcol->offset;
+ else
+ p->ti = 0;
+ break;
+ case -1:
+ if ((size_t)len < p->tcol->offset)
+ p->ti = -len;
+ else
+ p->ti = -p->tcol->offset;
+ break;
+ default:
+ if ((size_t)len > maxoff)
+ len = maxoff;
p->ti = len - p->tcol->offset;
- p->tcol->offset = len;
- } else if (sign == 1) {
- p->ti = len;
- p->tcol->offset += len;
- } else if ((size_t)len < p->tcol->offset) {
- p->ti = -len;
- p->tcol->offset -= len;
- } else {
- p->ti = -p->tcol->offset;
- p->tcol->offset = 0;
+ break;
}
+ p->tcol->offset += p->ti;
}