[BACK]Return to REarg.out_lint CVS log [TXT][DIR] Up to [cvsweb.bsd.lv] / mandoc / regress / man / RS

File: [cvsweb.bsd.lv] / mandoc / regress / man / RS / REarg.out_lint (download)

Revision 1.5, Fri Dec 21 17:15:20 2018 UTC (5 years, 4 months ago) by schwarze
Branch: MAIN
CVS Tags: VERSION_1_14_6, VERSION_1_14_5, HEAD
Changes since 1.4: +7 -7 lines

Rename mandoc_getarg() to roff_getarg() and pass it the roff parser
struct as an argument such that after copy-in, it can call roff_expand()
once again, which used to be called roff_res() before this.  This
fixes a subtle low-level roff(7) parsing bug reported by Fabio
Scotoni <fabio at esse dot ch> in the 4.4BSD-Lite2 mdoc.samples(7)
manual page, because that page used an escaped escape sequence in
a macro argument.

To expand escaped escape sequences in quoted mdoc(7) arguments, too,
stop bypassing the call to roff_getarg() in mdoc_argv.c, function args()
for this case.  This does not solve the case of escaped escape sequences
in quoted .Bl -column phrases yet.

Because roff_expand() can make the string longer, roff_getarg() can no
longer operate in-place but needs to malloc(3) the returned string.
In the high-level parsers, free(3) that string after processing it.

mandoc: REarg.in:8:8: ERROR: skipping excess arguments: RS ... 2i
mandoc: REarg.in:12:6: ERROR: skipping excess arguments: RE ... a
mandoc: REarg.in:14:6: ERROR: skipping excess arguments: RE ... b
mandoc: REarg.in:20:7: ERROR: skipping excess arguments: RE ... c
mandoc: REarg.in:26:6: ERROR: skipping excess arguments: RE ... d
mandoc: REarg.in:28:6: ERROR: skipping excess arguments: RE ... e
mandoc: REarg.in:28:2: ERROR: fewer RS blocks open, skipping: RE 1