]> git.cameronkatri.com Git - mandoc.git/commitdiff
Re-classify the roff(7) \r (reverse line feed) escape sequence
authorIngo Schwarze <schwarze@openbsd.org>
Fri, 20 May 2022 13:09:13 +0000 (13:09 +0000)
committerIngo Schwarze <schwarze@openbsd.org>
Fri, 20 May 2022 13:09:13 +0000 (13:09 +0000)
from "ignore" to "unsupported" because when an input file uses it,
mandoc(1) is likely to significantly misformat the output,
usually showing parts of the output in a different order
than the author intended.

regress/roff/esc/Makefile
regress/roff/esc/r.in [new file with mode: 0644]
regress/roff/esc/r.out_ascii [new file with mode: 0644]
regress/roff/esc/r.out_lint [new file with mode: 0644]
roff.7
roff_escape.c

index 111e59bc7154bd752fe35409eec207efd3dd37e5..bd39e37883df937af4cb5891af6753169c0a54a9 100644 (file)
@@ -1,15 +1,16 @@
-# $OpenBSD: Makefile,v 1.20 2022/05/01 16:18:59 schwarze Exp $
+# $OpenBSD: Makefile,v 1.21 2022/05/20 13:06:27 schwarze Exp $
 
 REGRESS_TARGETS         = one two multi comment
-REGRESS_TARGETS        += B bs_man bs_mdoc c c_man E1 e f h hneg l O1 o p w z
+REGRESS_TARGETS        += B bs_man bs_mdoc c c_man E1 e f h hneg l O1 o p w z
 REGRESS_TARGETS        += ignore invalid unsupp
 HTML_TARGETS    = f
-LINT_TARGETS    = comment B h l O1 w ignore invalid unsupp
+LINT_TARGETS    = comment B h l O1 w ignore invalid unsupp
 
-# mandoc defect:
+# mandoc defects:
 # - \h with a negative argument replaces output characters
 #   instead of overstriking them
+# - \r does not return to the previous output line
 
-SKIP_GROFF      = hneg
+SKIP_GROFF      = hneg r
 
 .include <bsd.regress.mk>
diff --git a/regress/roff/esc/r.in b/regress/roff/esc/r.in
new file mode 100644 (file)
index 0000000..835121d
--- /dev/null
@@ -0,0 +1,13 @@
+.\" $OpenBSD: r.in,v 1.1 2022/05/20 13:06:27 schwarze Exp $
+.Dd $Mdocdate: May 20 2022 $
+.Dt ESC-R 1
+.Os
+.Sh NAME
+.Nm esc-r
+.Nd the roff reverse line feed escape sequence
+.Sh DESCRIPTION
+.Bd -literal
+first line
+before\rafter
+last line
+.Ed
diff --git a/regress/roff/esc/r.out_ascii b/regress/roff/esc/r.out_ascii
new file mode 100644 (file)
index 0000000..83ec942
--- /dev/null
@@ -0,0 +1,11 @@
+ESC-R(1)                    General Commands Manual                   ESC-R(1)
+
+N\bNA\bAM\bME\bE
+     e\bes\bsc\bc-\b-r\br - the roff reverse line feed escape sequence
+
+D\bDE\bES\bSC\bCR\bRI\bIP\bPT\bTI\bIO\bON\bN
+     first line
+     beforeafter
+     last line
+
+OpenBSD                          May 20, 2022                          OpenBSD
diff --git a/regress/roff/esc/r.out_lint b/regress/roff/esc/r.out_lint
new file mode 100644 (file)
index 0000000..d86f19f
--- /dev/null
@@ -0,0 +1 @@
+mandoc: r.in:11:7: UNSUPP: unsupported escape sequence: \r
diff --git a/roff.7 b/roff.7
index 6c2e3583f69b9e899e53e8efad50697f3284c879..6ca3029d738ca3cdd3905d30f7342c6778da6f51 100644 (file)
--- a/roff.7
+++ b/roff.7
@@ -1,7 +1,7 @@
-.\"    $Id: roff.7,v 1.116 2021/09/18 12:23:06 schwarze Exp $
+.\" $Id: roff.7,v 1.117 2022/05/20 13:09:13 schwarze Exp $
 .\"
+.\" Copyright (c) 2010-2019, 2022 Ingo Schwarze <schwarze@openbsd.org>
 .\" Copyright (c) 2010, 2011, 2012 Kristaps Dzonsons <kristaps@bsd.lv>
-.\" Copyright (c) 2010-2019 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
@@ -15,7 +15,7 @@
 .\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
 .\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 .\"
-.Dd $Mdocdate: September 18 2021 $
+.Dd $Mdocdate: May 20 2022 $
 .Dt ROFF 7
 .Os
 .Sh NAME
@@ -2166,8 +2166,8 @@ Break the output line at the end of the current word.
 Set number register; ignored by
 .Xr mandoc 1 .
 .It Ic \er
-Move up by one line; ignored by
-.Xr mandoc 1 .
+Reverse line feed: move up by one output line.
+Currently unsupported.
 .It Ic \eS\(aq Ns Ar number Ns Ic \(aq
 Slant output; ignored by
 .Xr mandoc 1 .
index 1b5dc640b6afb78f60d74bc90365b91cbca8f8c9..fb7b92edde40b1473a74322551e69f37261d3f06 100644 (file)
@@ -103,6 +103,7 @@ roff_escape(const char *buf, const int ln, const int aesc,
 
        case '!':
        case '?':
+       case 'r':
                rval = ESCAPE_UNSUPP;
                goto out;
 
@@ -114,7 +115,6 @@ roff_escape(const char *buf, const int ln, const int aesc,
        case '^':
        case 'a':
        case 'd':
-       case 'r':
        case 't':
        case 'u':
        case '{':