[BACK]Return to w.out_lint CVS log [TXT][DIR] Up to [cvsweb.bsd.lv] / mandoc / regress / roff / esc

File: [cvsweb.bsd.lv] / mandoc / regress / roff / esc / w.out_lint (download)

Revision 1.8, Mon Oct 23 20:25:03 2023 UTC (7 months, 3 weeks ago) by schwarze
Branch: MAIN
CVS Tags: HEAD
Changes since 1.7: +5 -4 lines

Support some escape sequences, in particular character escape sequences,
inside \w arguments, and skip most other escape sequences when measuring
the output length in this way because most escape sequences contribute
little or nothing to text width: for example, consider font escapes in
terminal output.

This implementation is very rudimentary.  In particular, it assumes that
every character has the same width.  No attempt is made to detect
double-width or zero-width Unicode characters or to take dependencies on
output devices or fonts into account.  These limitations are hard to
avoid because mandoc has to interpolate \w at the parsing stage when the
output device is not yet known.  I really do not want the content of the
syntax tree to depend on the output device.

Feature requested by Paul <Eggert at cs dot ucla dot edu>, who also
submitted a patch, but i chose to commit this very different patch
with almost the same functionality.
His input was still very valuable because complete support for \w is
out of the question, and consequently, the main task is identifying
subsets of the feature that are needed for real-world manual pages
and can be supported without uprooting the whole forest.

mandoc: w.in:25:15: WARNING: undefined escape, printing literally: \G
mandoc: w.in:31:20: UNSUPP: unsupported escape sequence: \r
mandoc: w.in:31:23: UNSUPP: unsupported escape sequence: \r
mandoc: w.in:37:16: WARNING: undefined escape, printing literally: \G
mandoc: w.in:65:15: ERROR: incomplete escape sequence: \w'foo