.ss 12 0 .nr PI 0 .nr PD 0.5v .if n .nr PD 1v .de i \\fI\\$*\\fR\c .. .de bi \\f(BI\\$*\\fB\c .. .de cw \\f(CW\\$*\\fR\c .. .de cwb \\f(CB\\$*\\fR\c .. .TL .bi Lightroff , an alternative troff syntax .AU John Ankarström .DA 10 June 2022 .SH 1 Introduction .LP .i Lightroff is an alternative syntax for troff, visually inspired by SGML/XML. It differs from troff's default syntax in the following ways: .IP 1. 3 Lightroff requests begin with a less-than sign and end with a greater-than sign, e.g., \c .cw \ \&. These symbols may be escaped with a backslash.* .IP 2. Lightroff requests may be used inline. The following works as expected: \c .cw "(bold)" \&.** .IP 3. Lightroff ignores empty lines. .IP 4. Default troff syntax may be used between \c .cw \&. .LP The similarities with XML end at the visual level. Unlike XML, lightroff is unstructured and imperative. There is no concept of closing tags. .FS * For comparison, default troff requests begin with a newline and a control character, usually a period or an apostrophe, and end with another newline.\c .FE .FS ** Before an inline request, \c .cw lightroff automatically inserts a \c .cw \\\\c escape when appropriate.\c .FE .SH 1 Example .IP "" 3 .nf .eo \\fB\\$*\\fR<.> Example document John Doe Pellentesque dapibus suscipit ligula. Donec posuere augue in quam. Etiam vel tortor sodales tellus ultricies commodo. Suspendisse potenti. Aenean in sem ac leo mollis blandit. Donec neque quam, dignissim in, mollis nec, sagittis eu, wisi. Introduction vel est convallis dignissim. Fusce suscipit, wisi nec facilisis facilisis, est dui fermentum leo, quis tempor ligula erat quis odio. Nunc porta vulputate tellus. .ec .SH 1 .cwb Lightroff .PP The program \c .cw lightroff translates lightroff source to troff source. .SH 1 .cwb Lightroff-mode .PP For Emacs users, there is a major mode named \c .cw lightroff-mode that provides syntax highlighting for lightroff source. To further improve the writing experience, I also recommend \c .cw olivetti-mode \&. .SH 1 Caveats .LP Lightroff does not treat indented lines specially. As such, indentation cannot be used to convey structure.