From 7b8dd0a4ebf96c87a16d09fb8a7abd1070f8c229 Mon Sep 17 00:00:00 2001 From: Ingo Schwarze Date: Sun, 17 Aug 2014 18:42:08 +0000 Subject: Segfault fixes from kristaps@. Note that .It and .Nm blocks without bodies cannot be generated by valid mdoc(7) syntax but are a adequate representations of invalid mdoc(7) constructs like Bl -hang It Bo Sh and Sh SYNOPSIS Nm Bo Sh. --- regress/usr.bin/mandoc/mdoc/Nm/Makefile | 20 ++++++++++++++++---- regress/usr.bin/mandoc/mdoc/Nm/break.in | 12 ++++++++++++ regress/usr.bin/mandoc/mdoc/Nm/break.out_ascii | 12 ++++++++++++ regress/usr.bin/mandoc/mdoc/Nm/break.out_lint | 1 + 4 files changed, 41 insertions(+), 4 deletions(-) create mode 100644 regress/usr.bin/mandoc/mdoc/Nm/break.in create mode 100644 regress/usr.bin/mandoc/mdoc/Nm/break.out_ascii create mode 100644 regress/usr.bin/mandoc/mdoc/Nm/break.out_lint (limited to 'regress/usr.bin/mandoc/mdoc/Nm') diff --git a/regress/usr.bin/mandoc/mdoc/Nm/Makefile b/regress/usr.bin/mandoc/mdoc/Nm/Makefile index 8ec5dd751d2..02342262c48 100644 --- a/regress/usr.bin/mandoc/mdoc/Nm/Makefile +++ b/regress/usr.bin/mandoc/mdoc/Nm/Makefile @@ -1,9 +1,21 @@ -# $OpenBSD: Makefile,v 1.8 2014/08/11 04:18:18 schwarze Exp $ +# $OpenBSD: Makefile,v 1.9 2014/08/17 18:42:07 schwarze Exp $ -REGRESS_TARGETS = empty font emptyNAME emptyNAMEuse badNAME badNAMEuse long +REGRESS_TARGETS = badNAME badNAMEuse break empty emptyNAME emptyNAMEuse +REGRESS_TARGETS += font long -LINT_TARGETS = badNAME badNAMEuse +LINT_TARGETS = badNAME badNAMEuse break -SKIP_GROFF = emptyNAMEuse badNAMEuse +# groff-1.22.2/mandoc difference: +# When the first Nm does not have an argument but a later one has, +# mandoc retroactively uses the later name for the earlier instances +# of Nm, too, while groff does not. + +SKIP_GROFF = badNAMEuse emptyNAMEuse + +# groff-1.22.2 defect: +# When a SYNOPSIS Nm block head breaks a sub block, all the +# remaining content in the document gets lost. + +SKIP_GROFF += break .include diff --git a/regress/usr.bin/mandoc/mdoc/Nm/break.in b/regress/usr.bin/mandoc/mdoc/Nm/break.in new file mode 100644 index 00000000000..203ba98e3c5 --- /dev/null +++ b/regress/usr.bin/mandoc/mdoc/Nm/break.in @@ -0,0 +1,12 @@ +.Dd August 17, 2014 +.Dt NM-BREAK 1 +.Os OpenBSD +.Sh NAME +.Nm Nm-break +.Nd name block head breaking another block +.Sh SYNOPSIS +.Nm before Bo within +.Sh DESCRIPTION +initial text +.Nm +final text diff --git a/regress/usr.bin/mandoc/mdoc/Nm/break.out_ascii b/regress/usr.bin/mandoc/mdoc/Nm/break.out_ascii new file mode 100644 index 00000000000..8c62c9f7d3c --- /dev/null +++ b/regress/usr.bin/mandoc/mdoc/Nm/break.out_ascii @@ -0,0 +1,12 @@ +NM-BREAK(1) OpenBSD Reference Manual NM-BREAK(1) + +NNAAMMEE + NNmm--bbrreeaakk - name block head breaking another block + +SSYYNNOOPPSSIISS + bbeeffoorree [[wwiitthhiinn]] + +DDEESSCCRRIIPPTTIIOONN + initial text NNmm--bbrreeaakk final text + +OpenBSD August 17, 2014 OpenBSD diff --git a/regress/usr.bin/mandoc/mdoc/Nm/break.out_lint b/regress/usr.bin/mandoc/mdoc/Nm/break.out_lint new file mode 100644 index 00000000000..409b5812ae8 --- /dev/null +++ b/regress/usr.bin/mandoc/mdoc/Nm/break.out_lint @@ -0,0 +1 @@ +mandoc: break.in:9:2: ERROR: inserting missing end of block: Sh breaks Bo -- cgit v1.2.3