1 .\" $Id: mdoc.7,v 1.288 2021/12/06 16:26:08 schwarze Exp $
3 .\" Copyright (c) 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
4 .\" Copyright (c) 2010, 2011, 2013-2020 Ingo Schwarze <schwarze@openbsd.org>
6 .\" Permission to use, copy, modify, and distribute this software for any
7 .\" purpose with or without fee is hereby granted, provided that the above
8 .\" copyright notice and this permission notice appear in all copies.
10 .\" THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11 .\" WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12 .\" MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13 .\" ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14 .\" WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15 .\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16 .\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
18 .Dd $Mdocdate: December 6 2021 $
23 .Nd semantic markup language for formatting manual pages
27 language supports authoring of manual pages for the
29 utility by allowing semantic annotations of words, phrases,
30 page sections and complete manual pages.
31 Such annotations are used by formatting tools to achieve a uniform
32 presentation across all manuals written in
34 and to support hyperlinking if supported by the output medium.
36 This reference document describes the structure of manual pages
37 and the syntax and usage of the
40 The reference implementation of a parsing and formatting tool is
44 section describes compatibility with other implementations.
48 document, lines beginning with the control character
52 The first word is the macro name.
53 It consists of two or three letters.
54 Most macro names begin with a capital letter.
55 For a list of available macros, see
57 The words following the macro name are arguments to the macro, optionally
58 including the names of other, callable macros; see
62 Lines not beginning with the control character are called
64 They provide free-form text to be printed; the formatting of the text
65 depends on the respective processing context:
66 .Bd -literal -offset indent
67 \&.Sh Macro lines change control state.
68 Text lines are interpreted within the current state.
71 Many aspects of the basic syntax of the
73 language are based on the
81 manual for details, in particular regarding
82 comments, escape sequences, whitespace, and quoting.
87 documents is discouraged;
89 supports some of them merely for backward compatibility.
93 document consists of a document prologue followed by one or more
96 The prologue, which consists of the
101 macros in that order, is required for every document.
103 The first section (sections are denoted by
105 must be the NAME section, consisting of at least one
110 Following that, convention dictates specifying at least the
114 sections, although this varies between manual sections.
116 The following is a well-formed skeleton
120 .Bd -literal -offset indent
122 \&.Dt PROGNAME section
126 \&.Nd one line about what it does
127 \&.\e\(dq .Sh LIBRARY
128 \&.\e\(dq For sections 2, 3, and 9 only.
129 \&.\e\(dq Not used in OpenBSD.
137 utility processes files ...
138 \&.\e\(dq .Sh CONTEXT
139 \&.\e\(dq For section 9 functions only.
140 \&.\e\(dq .Sh IMPLEMENTATION NOTES
141 \&.\e\(dq Not used in OpenBSD.
142 \&.\e\(dq .Sh RETURN VALUES
143 \&.\e\(dq For sections 2, 3, and 9 function return values only.
144 \&.\e\(dq .Sh ENVIRONMENT
145 \&.\e\(dq For sections 1, 6, 7, and 8 only.
147 \&.\e\(dq .Sh EXIT STATUS
148 \&.\e\(dq For sections 1, 6, and 8 only.
149 \&.\e\(dq .Sh EXAMPLES
150 \&.\e\(dq .Sh DIAGNOSTICS
151 \&.\e\(dq For sections 1, 4, 6, 7, 8, and 9 printf/stderr messages only.
153 \&.\e\(dq For sections 2, 3, 4, and 9 errno settings only.
154 \&.\e\(dq .Sh SEE ALSO
155 \&.\e\(dq .Xr foobar 1
156 \&.\e\(dq .Sh STANDARDS
157 \&.\e\(dq .Sh HISTORY
158 \&.\e\(dq .Sh AUTHORS
159 \&.\e\(dq .Sh CAVEATS
161 \&.\e\(dq .Sh SECURITY CONSIDERATIONS
162 \&.\e\(dq Not used in OpenBSD.
167 document are conventionally ordered as they appear above.
168 Sections should be composed as follows:
169 .Bl -ohang -offset Ds
171 The name(s) and a one line description of the documented material.
172 The syntax for this as follows:
173 .Bd -literal -offset indent
177 \&.Nd a one line description
182 names should be separated by commas.
186 macro(s) must precede the
195 The name of the library containing the documented material, which is
196 assumed to be a function in a section 2, 3, or 9 manual.
197 The syntax for this is as follows:
198 .Bd -literal -offset indent
205 Documents the utility invocation syntax, function call syntax, or device
208 For the first, utilities (sections 1, 6, and 8), this is
209 generally structured as follows:
210 .Bd -literal -offset indent
221 Commands should be ordered alphabetically.
223 For the second, function calls (sections 2, 3, 9):
224 .Bd -literal -offset indent
226 \&.Vt extern const char *global;
228 \&.Fn foo "const char *src"
230 \&.Fn bar "const char *src"
239 macros should follow C header-file conventions.
241 And for the third, configurations (section 4):
242 .Bd -literal -offset indent
243 \&.Cd \(dqit* at isa? port 0x2e\(dq
244 \&.Cd \(dqit* at isa? port 0x4e\(dq
247 Manuals not in these sections generally don't need a
250 Some macros are displayed differently in the
252 section, particularly
262 All of these macros are output on their own line.
263 If two such dissimilar macros are pairwise invoked (except for
269 they are separated by a vertical space, unless in the case of
274 which are always separated by vertical space.
276 When text and macros following an
278 macro starting an input line span multiple output lines,
279 all output lines but the first will be indented to align
280 with the text immediately following the
282 macro, up to the next
287 macro or the end of an enclosing block, whichever comes first.
289 This begins with an expansion of the brief, one line description in
291 .Bd -literal -offset indent
294 utility does this, that, and the other.
297 It usually follows with a breakdown of the options (if documenting a
299 .Bd -literal -offset indent
300 The options are as follows:
301 \&.Bl \-tag \-width Ds
303 Print verbose information.
307 List the options in alphabetical order,
308 uppercase before lowercase for each letter and
309 with no regard to whether an option takes an argument.
310 Put digits in ascending order before all letter options.
312 Manuals not documenting a command won't include the above fragment.
316 section usually contains most of the text of a manual, longer manuals
319 macro to form subsections.
320 In very long manuals, the
322 may be split into multiple sections, each started by an
324 macro followed by a non-standard section name, and each having
325 several subsections, like in the present
329 This section lists the contexts in which functions can be called in section 9.
330 The contexts are autoconf, process, or interrupt.
331 .It Em IMPLEMENTATION NOTES
332 Implementation-specific notes should be kept here.
333 This is useful when implementing standard functions that may have side
334 effects or notable algorithmic implications.
336 This section documents the
337 return values of functions in sections 2, 3, and 9.
342 Lists the environment variables used by the utility,
343 and explains the syntax and semantics of their values.
346 manual provides examples of typical content and formatting.
351 Documents files used.
352 It's helpful to document both the file name and a short description of how
353 the file is used (created, modified, etc.).
358 This section documents the
359 command exit status for section 1, 6, and 8 utilities.
360 Historically, this information was described in
362 a practise that is now discouraged.
368 This often contains snippets of well-formed, well-tested invocations.
369 Make sure that examples work properly!
371 Documents error messages.
372 In section 4 and 9 manuals, these are usually messages printed by the
373 kernel to the console and to the kernel log.
374 In section 1, 6, 7, and 8, these are usually messages printed by
375 userland programs to the standard error output.
377 Historically, this section was used in place of
379 for manuals in sections 1, 6, and 8; however, this practise is
388 settings in sections 2, 3, 4, and 9.
393 References other manuals with related topics.
394 This section should exist for most manuals.
395 Cross-references should conventionally be ordered first by section, then
396 alphabetically (ignoring case).
398 References to other documentation concerning the topic of the manual page,
399 for example authoritative books or journal articles, may also be
400 provided in this section.
407 References any standards implemented or used.
408 If not adhering to any standards, the
410 section should be used instead.
415 A brief history of the subject, including where it was first implemented,
416 and when it was ported to or reimplemented for the operating system at hand.
418 Credits to the person or persons who wrote the code and/or documentation.
419 Authors should generally be noted by both name and email address.
424 Common misuses and misunderstandings should be explained
427 Known bugs, limitations, and work-arounds should be described
429 .It Em SECURITY CONSIDERATIONS
430 Documents any security precautions that operators should consider.
433 This overview is sorted such that macros of similar purpose are listed
434 together, to help find the best macro for any given purpose.
435 Deprecated macros are not included in the overview, but can be found below
437 .Sx MACRO REFERENCE .
438 .Ss Document preamble and NAME section macros
439 .Bl -column "Brq, Bro, Brc" description
440 .It Ic \&Dd Ta document date: Cm $\&Mdocdate$ | Ar month day , year
441 .It Ic \&Dt Ta document title: Ar TITLE section Op Ar arch
442 .It Ic \&Os Ta operating system version: Op Ar system Op Ar version
443 .It Ic \&Nm Ta document name (one argument)
444 .It Ic \&Nd Ta document description (one line)
446 .Ss Sections and cross references
447 .Bl -column "Brq, Bro, Brc" description
448 .It Ic \&Sh Ta section header (one line)
449 .It Ic \&Ss Ta subsection header (one line)
450 .It Ic \&Sx Ta internal cross reference to a section or subsection
451 .It Ic \&Xr Ta cross reference to another manual page: Ar name section
452 .It Ic \&Tg Ta tag the definition of a Ar term Pq <= 1 arguments
453 .It Ic \&Pp Ta start a text paragraph (no arguments)
455 .Ss Displays and lists
456 .Bl -column "Brq, Bro, Brc" description
457 .It Ic \&Bd , \&Ed Ta display block:
459 .Op Fl offset Ar width
461 .It Ic \&D1 Ta indented display (one line)
462 .It Ic \&Dl Ta indented literal display (one line)
463 .It Ic \&Ql Ta in-line literal display: Ql text
464 .It Ic \&Bl , \&El Ta list block:
469 .It Ic \&It Ta list item (syntax depends on Fl Ar type )
470 .It Ic \&Ta Ta table cell separator in Ic \&Bl Fl column No lists
471 .It Ic \&Rs , \&%* , \&Re Ta bibliographic block (references)
474 .Bl -column "Brq, Bro, Brc" description
475 .It Ic \&Pf Ta prefix, no following horizontal space (one argument)
476 .It Ic \&Ns Ta roman font, no preceding horizontal space (no arguments)
477 .It Ic \&Ap Ta apostrophe without surrounding whitespace (no arguments)
478 .It Ic \&Sm Ta switch horizontal spacing mode: Op Cm on | off
479 .It Ic \&Bk , \&Ek Ta keep block: Fl words
481 .Ss Semantic markup for command line utilities
482 .Bl -column "Brq, Bro, Brc" description
483 .It Ic \&Nm Ta start a SYNOPSIS block with the name of a utility
484 .It Ic \&Fl Ta command line options (flags) (>=0 arguments)
485 .It Ic \&Cm Ta command modifier (>0 arguments)
486 .It Ic \&Ar Ta command arguments (>=0 arguments)
487 .It Ic \&Op , \&Oo , \&Oc Ta optional syntax elements (enclosure)
488 .It Ic \&Ic Ta internal or interactive command (>0 arguments)
489 .It Ic \&Ev Ta environmental variable (>0 arguments)
490 .It Ic \&Pa Ta file system path (>=0 arguments)
492 .Ss Semantic markup for function libraries
493 .Bl -column "Brq, Bro, Brc" description
494 .It Ic \&Lb Ta function library (one argument)
495 .It Ic \&In Ta include file (one argument)
496 .It Ic \&Fd Ta other preprocessor directive (>0 arguments)
497 .It Ic \&Ft Ta function type (>0 arguments)
498 .It Ic \&Fo , \&Fc Ta function block: Ar funcname
499 .It Ic \&Fn Ta function name: Ar funcname Op Ar argument ...
500 .It Ic \&Fa Ta function argument (>0 arguments)
501 .It Ic \&Vt Ta variable type (>0 arguments)
502 .It Ic \&Va Ta variable name (>0 arguments)
503 .It Ic \&Dv Ta defined variable or preprocessor constant (>0 arguments)
504 .It Ic \&Er Ta error constant (>0 arguments)
505 .It Ic \&Ev Ta environmental variable (>0 arguments)
507 .Ss Various semantic markup
508 .Bl -column "Brq, Bro, Brc" description
509 .It Ic \&An Ta author name (>0 arguments)
510 .It Ic \&Lk Ta hyperlink: Ar uri Op Ar display_name
511 .It Ic \&Mt Ta Do mailto Dc hyperlink: Ar localpart Ns @ Ns Ar domain
512 .It Ic \&Cd Ta kernel configuration declaration (>0 arguments)
513 .It Ic \&Ad Ta memory address (>0 arguments)
514 .It Ic \&Ms Ta mathematical symbol (>0 arguments)
517 .Bl -column "Brq, Bro, Brc" description
518 .It Ic \&Em Ta italic font or underline (emphasis) (>0 arguments)
519 .It Ic \&Sy Ta boldface font (symbolic) (>0 arguments)
520 .It Ic \&No Ta return to roman font (normal) (>0 arguments)
521 .It Ic \&Bf , \&Ef Ta font block: Fl Ar type | Cm \&Em | \&Li | \&Sy
523 .Ss Physical enclosures
524 .Bl -column "Brq, Bro, Brc" description
525 .It Ic \&Dq , \&Do , \&Dc Ta enclose in typographic double quotes: Dq text
526 .It Ic \&Qq , \&Qo , \&Qc Ta enclose in typewriter double quotes: Qq text
527 .It Ic \&Sq , \&So , \&Sc Ta enclose in single quotes: Sq text
528 .It Ic \&Pq , \&Po , \&Pc Ta enclose in parentheses: Pq text
529 .It Ic \&Bq , \&Bo , \&Bc Ta enclose in square brackets: Bq text
530 .It Ic \&Brq , \&Bro , \&Brc Ta enclose in curly braces: Brq text
531 .It Ic \&Aq , \&Ao , \&Ac Ta enclose in angle brackets: Aq text
532 .It Ic \&Eo , \&Ec Ta generic enclosure
535 .Bl -column "Brq, Bro, Brc" description
536 .It Ic \&Ex Fl std Ta standard command exit values: Op Ar utility ...
537 .It Ic \&Rv Fl std Ta standard function return values: Op Ar function ...
538 .It Ic \&St Ta reference to a standards document (one argument)
548 This section is a canonical reference of all macros, arranged
550 For the scoping of individual macros, see
553 .It Ic \&%A Ar first_name ... last_name
557 Multiple authors should each be accorded their own
560 Author names should be ordered with full or abbreviated forename(s)
561 first, then full surname.
566 This macro may also be used in a non-bibliographic context when
567 referring to book titles.
568 .It Ic \&%C Ar location
569 Publication city or location of an
572 .It Ic \&%D Oo Ar month day , Oc Ar year
573 Publication date of an
576 Provide the full English name of the
578 and all four digits of the
581 Publisher or issuer name of an
588 .It Ic \&%N Ar number
589 Issue number (usually for journals) of an
593 Optional information of an
596 .It Ic \&%P Ar number
597 Book or journal page number of an
600 Conventionally, the argument starts with
604 for a range of pages, for example:
606 .Dl .%P pp. 42\e(en47
608 Institutional author (school, government, etc.) of an
611 Multiple institutional authors should each be accorded their own
615 Technical report name of an
622 This macro may also be used in a non-bibliographical context when
623 referring to article titles.
624 .It Ic \&%U Ar protocol Ns :// Ns Ar path
625 URI of reference document.
626 .It Ic \&%V Ar number
634 Does not have any tail arguments.
636 .It Ic \&Ad Ar address
638 Do not use this for postal addresses.
644 .It Ic \&An Fl split | nosplit | Ar first_name ... last_name
646 Can be used both for the authors of the program, function, or driver
647 documented in the manual, or for the authors of the manual itself.
648 Requires either the name of an author or one of the following arguments:
650 .Bl -tag -width "-nosplitX" -offset indent -compact
652 Start a new output line before each subsequent invocation of
661 The effect of selecting either of the
663 modes ends at the beginning of the
668 section, the default is
670 for the first author listing and
672 for all other author listings.
676 .Dl \&.An Kristaps Dzonsons \&Aq \&Mt kristaps@bsd.lv
678 Begin a block enclosed by angle brackets.
679 Does not have any head arguments.
680 This macro is almost never useful.
686 Inserts an apostrophe without any surrounding whitespace.
687 This is generally used as a grammatical device when referring to the verb
691 .Dl \&.Fn execve \&Ap d
694 Enclose the rest of the input line in angle brackets.
695 The only important use case is for email addresses.
700 Occasionally, it is used for names of characters and keys, for example:
701 .Bd -literal -offset indent
721 usually renders with non-ASCII characters in non-ASCII output modes,
722 do not use it where the ASCII characters
726 are required as syntax elements.
727 Instead, use these characters directly in such cases, combining them
738 .It Ic \&Ar Op Ar placeholder ...
740 If an argument is not provided, the string
742 is used as a default.
747 .Dl ".Ar arg1 , arg2 ."
751 macro are names and placeholders for command arguments;
752 for fixed strings to be passed verbatim as arguments, use
757 .It Ic \&At Op Ar version
761 Accepts one optional argument:
763 .Bl -tag -width "v[1-7] | 32vX" -offset indent -compact
774 Note that these arguments do not begin with a hyphen.
793 Does not have any tail arguments.
795 .It Ic \&Bd Fl Ns Ar type Oo Fl offset Ar width Oc Op Fl compact
796 Begin a display block.
797 Display blocks are used to select a different indentation and
798 justification than the one used by the surrounding text.
799 They may contain both macro lines and text lines.
800 By default, a display block is preceded by a vertical space.
804 must be one of the following:
805 .Bl -tag -width 13n -offset indent
807 Produce one output line from each input line, and center-justify each line.
808 Using this display type is not recommended; many
810 implementations render it poorly.
812 Change the positions of line breaks to fill each line, and left- and
813 right-justify the resulting block.
815 Produce one output line from each input line,
816 and do not justify the block at all.
817 Preserve white space as it appears in the input.
818 Always use a constant-width font.
819 Use this for displaying source code.
821 Change the positions of line breaks to fill each line, and left-justify
826 but using the same font as for normal text, which is a variable width font
827 if supported by the output device.
832 must be provided first.
833 Additional arguments may follow:
834 .Bl -tag -width 13n -offset indent
835 .It Fl offset Ar width
836 Indent the display by the
838 which may be one of the following:
841 One of the pre-defined strings
843 the width of a standard indentation (six constant width characters);
850 which justifies to the right margin; or
852 which aligns around an imagined center axis.
854 A macro invocation, which selects a predefined width
855 associated with that macro.
856 The most popular is the imaginary macro
861 A scaling width as described in
864 An arbitrary string, which indents by the length of this string.
867 When the argument is missing,
871 Do not assert vertical space before the display.
875 .Bd -literal -offset indent
876 \&.Bd \-literal \-offset indent \-compact
886 .It Ic \&Bf Fl emphasis | literal | symbolic | Cm \&Em | \&Li | \&Sy
887 Change the font mode for a scoped block of text.
892 argument are equivalent, as are
900 Without an argument, this macro does nothing.
901 The font mode continues until broken by a new font mode in a nested
914 For each macro, keep its output together on the same output line,
915 until the end of the macro or the end of the input line is reached,
916 whichever comes first.
917 Line breaks in text lines are unaffected.
921 argument is required; additional arguments are ignored.
923 The following example will not break within each
926 .Bd -literal -offset indent
933 Be careful in using over-long lines within a keep block!
934 Doing so will clobber the right margin.
945 Lists consist of items specified using the
947 macro, containing a head or a body or both.
951 is mandatory and must be specified first.
956 arguments accept macro names as described for
959 scaling widths as described in
961 or use the length of the given string.
964 is a global indentation for the whole list, affecting both item heads
966 For those list types supporting it, the
968 argument requests an additional indentation of item bodies,
973 argument is specified, list entries are separated by vertical space.
975 A list must specify one of the following list types:
976 .Bl -tag -width 12n -offset indent
978 No item heads can be specified, but a bullet will be printed at the head
980 Item bodies start on the same output line as the bullet
981 and are indented according to the
988 argument has no effect; instead, the string length of each argument
989 specifies the width of one column.
990 If the first line of the body of a
996 contexts spanning one input line each are implied until an
998 macro line is encountered, at which point items start being interpreted as
1005 except that dashes are used in place of bullets.
1009 except that item heads are not parsed for macro invocations.
1010 Most often used in the
1012 section with error constants in the item heads.
1015 No item heads can be specified.
1018 except that cardinal numbers are used in place of bullets,
1023 except that the first lines of item bodies are not indented, but follow
1024 the item heads like in
1031 Item bodies follow items heads on the same line, using normal inter-word
1033 Bodies are not indented, and the
1035 argument is ignored.
1037 No item heads can be specified, and none are printed.
1038 Bodies are not indented, and the
1040 argument is ignored.
1042 Item bodies start on the line following item heads and are not indented.
1045 argument is ignored.
1047 Item bodies are indented according to the
1050 When an item head fits inside the indentation, the item body follows
1051 this head on the same output line.
1052 Otherwise, the body starts on the output line following the head.
1055 Lists may be nested within lists and displays.
1060 lists may not be portable.
1066 .It Ic \&Bo Ar block
1067 Begin a block enclosed by square brackets.
1068 Does not have any head arguments.
1071 .Bd -literal -offset indent -compact
1080 Encloses its arguments in square brackets.
1083 .Dl \&.Bq 1 , \&Dv BUFSIZ
1086 this macro is sometimes abused to emulate optional arguments for
1087 commands; the correct macros to use for this purpose are
1099 Does not have any tail arguments.
1100 .It Ic \&Bro Ar block
1101 Begin a block enclosed by curly braces.
1102 Does not have any head arguments.
1105 .Bd -literal -offset indent -compact
1113 .It Ic \&Brq Ar line
1114 Encloses its arguments in curly braces.
1117 .Dl \&.Brq 1 , ... , \&Va n
1122 .It Ic \&Bsx Op Ar version
1125 version provided as an argument, or a default value if
1126 no argument is provided.
1141 Supported only for compatibility, do not use this in new manuals.
1143 .Dq is currently in beta test.
1145 .It Ic \&Bx Op Ar version Op Ar variant
1148 version provided as an argument, or a default value if no
1149 argument is provided.
1166 Kernel configuration declaration.
1167 This denotes strings accepted by
1169 It is most often used in section 4 manual pages.
1172 .Dl \&.Cd device le0 at scode?
1175 this macro is commonly abused by using quoted literals to retain
1176 whitespace and align consecutive
1179 This practise is discouraged.
1181 .It Ic \&Cm Ar keyword ...
1183 Typically used for fixed strings passed as arguments to interactive
1184 commands, to commands in interpreted scripts, or to configuration
1185 file directives, unless
1187 is more appropriate.
1190 .Dl ".Nm mt Fl f Ar device Cm rewind"
1191 .Dl ".Nm ps Fl o Cm pid , Ns Cm command"
1192 .Dl ".Nm dd Cm if= Ns Ar file1 Cm of= Ns Ar file2"
1193 .Dl ".Ic set Fl o Cm vi"
1194 .Dl ".Ic lookup Cm file bind"
1195 .Dl ".Ic permit Ar identity Op Cm as Ar target"
1198 One-line indented display.
1199 This is formatted by the default rules and is useful for simple indented
1201 It is followed by a newline.
1204 .Dl \&.D1 \&Fl abcdefgh
1211 This macro is obsolete.
1212 No replacement is needed.
1215 and groff including its arguments.
1216 It was formerly used to toggle a debugging mode.
1221 Does not have any tail arguments.
1223 .It Ic \&Dd Cm $\&Mdocdate$ | Ar month day , year
1224 Document date for display in the page footer,
1225 by convention the date of the last change.
1226 This is the mandatory first macro of any
1232 is the full English month name, the
1234 is an integer number, and the
1236 is the full four-digit year.
1238 Other arguments are not portable; the
1240 utility handles them as follows:
1241 .Bl -dash -offset 3n -compact
1243 To have the date automatically filled in by the
1249 can be given as an argument.
1251 The traditional, purely numeric
1254 .Ar year Ns \(en Ns Ar month Ns \(en Ns Ar day
1257 If a date string cannot be parsed, it is used verbatim.
1259 If no date string is given, the current date is used.
1263 .Dl \&.Dd $\&Mdocdate$
1264 .Dl \&.Dd $\&Mdocdate: July 2 2018$
1265 .Dl \&.Dd July 2, 2018
1273 One-line indented display.
1274 This is formatted as literal text and is useful for commands and
1276 It is followed by a newline.
1279 .Dl \&.Dl % mandoc mdoc.7 \e(ba less
1283 .Ic \&Bd Fl literal ,
1286 .It Ic \&Do Ar block
1287 Begin a block enclosed by double quotes.
1288 Does not have any head arguments.
1291 .Bd -literal -offset indent -compact
1293 April is the cruellest month
1302 Encloses its arguments in
1307 .Bd -literal -offset indent -compact
1308 \&.Dq April is the cruellest month
1318 .It Ic \&Dt Ar TITLE section Op Ar arch
1319 Document title for display in the page header.
1320 This is the mandatory second macro of any
1324 Its arguments are as follows:
1325 .Bl -tag -width section -offset 2n
1327 The document's title (name), defaulting to
1330 To achieve a uniform appearance of page header lines,
1331 it should by convention be all caps.
1336 .Pq General Commands ,
1340 .Pq Library Functions ,
1344 .Pq Device Drivers ,
1350 .Pq Miscellaneous Information ,
1352 .Pq System Manager's Manual ,
1355 .Pq Kernel Developer's Manual .
1356 It should correspond to the manual's filename suffix and defaults to
1357 the empty string if unspecified.
1359 This specifies the machine architecture a manual page applies to,
1360 where relevant, for example
1366 The list of valid architectures varies by operating system.
1371 .Dl \&.Dt FOO 9 i386
1378 .It Ic \&Dv Ar identifier ...
1379 Defined variables such as preprocessor constants, constant symbols,
1380 enumeration values, and so on.
1385 .Dl \&.Dv STDOUT_FILENO
1391 for special-purpose constants,
1393 for variable symbols, and
1395 for listing preprocessor variable definitions in the
1398 .It Ic \&Dx Op Ar version
1401 version provided as an argument, or a default
1402 value if no argument is provided.
1416 .It Ic \&Ec Op Ar closing_delimiter
1417 Close a scope started by
1421 .Ar closing_delimiter
1422 argument is used as the enclosure tail, for example, specifying \e(rq
1426 End a display context started by
1429 End a font mode context started by
1432 End a keep context started by
1435 End a list context started by
1440 .It Ic \&Em Ar word ...
1441 Request an italic font.
1442 If the output device does not provide that, underline.
1444 This is most often used for stress emphasis (not to be confused with
1447 In the rare cases where none of the semantic markup macros fit,
1448 it can also be used for technical terms and placeholders, except
1449 that for syntax elements,
1453 are preferred, respectively.
1456 .Bd -literal -compact -offset indent
1457 Selected lines are those
1459 matching any of the specified patterns.
1460 Some of the functions use a
1462 to save the pattern space for subsequent retrieval.
1470 .It Ic \&En Ar word ...
1471 This macro is obsolete.
1474 or any of the other enclosure macros.
1476 It encloses its argument in the delimiters specified by the last
1480 .It Ic \&Eo Op Ar opening_delimiter
1481 An arbitrary enclosure.
1483 .Ar opening_delimiter
1484 argument is used as the enclosure head, for example, specifying \e(lq
1488 .It Ic \&Er Ar identifier ...
1489 Error constants for definitions of the
1491 libc global variable.
1492 This is most often used in section 2 and 3 manual pages.
1500 for general constants.
1501 .It Ic \&Es Ar opening_delimiter closing_delimiter
1502 This macro is obsolete.
1505 or any of the other enclosure macros.
1507 It takes two arguments, defining the delimiters to be used by subsequent
1511 .It Ic \&Ev Ar identifier ...
1512 Environmental variables such as those specified in
1521 for general constants.
1523 .It Ic \&Ex Fl std Op Ar utility ...
1524 Insert a standard sentence regarding command exit values of 0 on success
1526 This is most often used in section 1, 6, and 8 manual pages.
1530 is not specified, the document's name set by
1535 arguments are treated as separate utilities.
1540 .It Ic \&Fa Ar argument ...
1541 Function argument or parameter.
1542 Each argument may be a name and a type (recommended for the
1544 section), a name alone (for function invocations),
1545 or a type alone (for function prototypes).
1546 If both a type and a name are given or if the type consists of multiple
1547 words, all words belonging to the same function argument have to be
1548 given in a single argument to the
1552 This macro is also used to specify the field name of a structure.
1556 macro is used in the
1560 blocks when documenting multi-line function prototypes.
1561 If invoked with multiple arguments, the arguments are separated by a
1563 Furthermore, if the following macro is another
1565 the last argument will also have a trailing comma.
1568 .Dl \&.Fa \(dqconst char *p\(dq
1569 .Dl \&.Fa \(dqint a\(dq \(dqint b\(dq \(dqint c\(dq
1570 .Dl \&.Fa \(dqchar *\(dq size_t
1575 End a function context started by
1578 .It Ic \&Fd Pf # Ar directive Op Ar argument ...
1579 Preprocessor directive, in particular for listing it in the
1581 Historically, it was also used to document include files.
1582 The latter usage has been deprecated in favour of
1586 .Dl \&.Fd #define sa_handler __sigaction_u.__sa_handler
1587 .Dl \&.Fd #define SIO_MAXNFDS
1588 .Dl \&.Fd #ifdef FS_DEBUG
1590 .Dl \&.Fn dbg_open \(dqconst char *\(dq
1594 .Sx MANUAL STRUCTURE ,
1599 .It Ic \&Fl Op Ar word ...
1600 Command-line flag or option.
1601 Used when listing arguments to command-line utilities.
1602 For each argument, prints an ASCII hyphen-minus character
1604 immediately followed by the argument.
1605 If no arguments are provided, a hyphen-minus is printed followed by a space.
1606 If the argument is a macro, a hyphen-minus is prefixed
1607 to the subsequent macro output.
1610 .Dl ".Nm du Op Fl H | L | P"
1611 .Dl ".Nm ls Op Fl 1AaCcdFfgHhikLlmnopqRrSsTtux"
1612 .Dl ".Nm route Cm add Fl inet Ar destination gateway"
1613 .Dl ".Nm locate.updatedb Op Fl \e-fcodes Ns = Ns Ar dbfile"
1614 .Dl ".Nm aucat Fl o Fl"
1615 .Dl ".Nm kill Fl Ar signal_number"
1617 For GNU-style long options, escaping the additional hyphen-minus is not
1618 strictly required, but may be safer with future versions of GNU troff; see
1625 .It Ic \&Fn Ar funcname Op Ar argument ...
1628 Function arguments are surrounded in parenthesis and
1629 are delimited by commas.
1630 If no arguments are specified, blank parenthesis are output.
1633 section, this macro starts a new output line,
1634 and a blank line is automatically inserted between function definitions.
1637 .Dl \&.Fn \(dqint funcname\(dq \(dqint arg0\(dq \(dqint arg1\(dq
1638 .Dl \&.Fn funcname \(dqint arg0\(dq
1639 .Dl \&.Fn funcname arg0
1640 .Bd -literal -offset indent
1645 When referring to a function documented in another manual page, use
1649 .Sx MANUAL STRUCTURE ,
1654 .It Ic \&Fo Ar funcname
1655 Begin a function block.
1656 This is a multi-line version of
1659 Invocations usually occur in the following context:
1660 .Bd -ragged -offset indent
1661 .Pf \. Ic \&Ft Ar functype
1663 .Pf \. Ic \&Fo Ar funcname
1665 .Pf \. Ic \&Fa Qq Ar argtype Ar argname
1678 .Sx MANUAL STRUCTURE ,
1683 .It Ic \&Fr Ar number
1684 This macro is obsolete.
1685 No replacement markup is needed.
1687 It was used to show numerical function return values in an italic font.
1689 .It Ic \&Ft Ar functype
1694 section, a new output line is started after this macro.
1698 .Bd -literal -offset indent -compact
1704 .Sx MANUAL STRUCTURE ,
1709 .It Ic \&Fx Op Ar version
1712 version provided as an argument, or a default value
1713 if no argument is provided.
1727 .It Ic \&Hf Ar filename
1728 This macro is not implemented in
1730 It was used to include the contents of a (header) file literally.
1732 .It Ic \&Ic Ar keyword ...
1733 Internal or interactive command, or configuration instruction
1734 in a configuration file.
1748 is preferred for displaying code samples; the
1750 macro is used when referring to an individual command name.
1752 .It Ic \&In Ar filename
1753 The name of an include file.
1754 This macro is most often used in section 2, 3, and 9 manual pages.
1756 When invoked as the first macro on an input line in the
1758 section, the argument is displayed in angle brackets
1761 and a blank line is inserted in front if there is a preceding
1762 function declaration.
1763 In other sections, it only encloses its argument in angle brackets
1764 and causes no line break.
1767 .Dl \&.In sys/types.h
1770 .Sx MANUAL STRUCTURE .
1772 .It Ic \&It Op Ar head
1774 The syntax of this macro depends on the list type.
1783 have the following syntax:
1785 .D1 Pf \. Ic \&It Ar args
1794 have the following syntax:
1798 with subsequent lines interpreted within the scope of the
1800 until either a closing
1807 list has the following syntax:
1809 .D1 Pf \. Ic \&It Op Cm args
1811 Subsequent lines are interpreted as with
1814 The line arguments correspond to the list's left-hand side; body
1815 arguments correspond to the list's contents.
1819 list is the most complicated.
1820 Its syntax is as follows:
1822 .D1 Pf \. Ic \&It Ar cell Op Ic \&Ta Ar cell ...
1823 .D1 Pf \. Ic \&It Ar cell Op <TAB> Ar cell ...
1825 The arguments consist of one or more lines of text and macros
1826 representing a complete table line.
1827 Cells within the line are delimited by the special
1829 block macro or by literal tab characters.
1831 Using literal tabs is strongly discouraged because they are very
1832 hard to use correctly and
1834 code using them is very hard to read.
1835 In particular, a blank character is syntactically significant
1836 before and after the literal tab character.
1837 If a word precedes or follows the tab without an intervening blank,
1838 that word is never interpreted as a macro call, but always output
1841 The tab cell delimiter may only be used within the
1843 line itself; on following lines, only the
1845 macro can be used to delimit cells, and portability requires that
1847 is called by other macros: some parsers do not recognize it when
1848 it appears as the first macro on a line.
1850 Note that quoted strings may span tab-delimited cells on an
1855 .Dl .It \(dqcol1 ,\& <TAB> col2 ,\(dq \&;
1857 will preserve the whitespace before both commas,
1858 but not the whitespace before the semicolon.
1863 .It Ic \&Lb Cm lib Ns Ar name
1868 parameter may be a system library, such as
1872 in which case a small library description is printed next to the linker
1873 invocation; or a custom library, in which case the library name is
1875 This is most commonly used in the
1877 section as described in
1878 .Sx MANUAL STRUCTURE .
1884 .It Ic \&Li Ar word ...
1885 Request a typewriter (literal) font.
1886 Deprecated because on terminal output devices, this is usually
1887 indistinguishable from normal text.
1888 For literal displays, use
1889 .Ic \&Ql Pq in-line ,
1890 .Ic \&Dl Pq single line ,
1892 .Ic \&Bd Fl literal Pq multi-line
1895 .It Ic \&Lk Ar uri Op Ar display_name
1899 .Dl \&.Lk https://bsd.lv \(dqThe BSD.lv Project\(dq
1900 .Dl \&.Lk https://bsd.lv
1905 Deprecated synonym for
1909 Display a mathematical symbol.
1915 .It Ic \&Mt Ar localpart Ns @ Ns Ar domain
1921 .Dl \&.Mt discuss@manpages.bsd.lv
1922 .Dl \&.An Kristaps Dzonsons \&Aq \&Mt kristaps@bsd.lv
1925 A one line description of the manual's content.
1926 This is the mandatory last macro of the
1928 section and not appropriate for other sections.
1931 .Dl Pf . Ic \&Nd mdoc language reference
1932 .Dl Pf . Ic \&Nd format and display UNIX manuals
1936 macro technically accepts child macros and terminates with a subsequent
1939 Do not assume this behaviour: some
1941 database generators are not smart enough to parse more than the line
1942 arguments and will display macros verbatim.
1947 .It Ic \&Nm Op Ar name
1948 The name of the manual page, or \(em in particular in section 1, 6,
1949 and 8 pages \(em of an additional command or feature documented in
1951 When first invoked, the
1953 macro expects a single argument, the name of the manual page.
1954 Usually, the first invocation happens in the
1956 section of the page.
1957 The specified name will be remembered and used whenever the macro is
1958 called again without arguments later in the page.
1962 .Sx Block full-implicit
1963 semantics when invoked as the first macro on an input line in the
1965 section; otherwise, it uses ordinary
1970 .Bd -literal -offset indent
1979 of section 2, 3 and 9 manual pages, use the
1983 to mark up the name of the manual page.
1985 .It Ic \&No Ar word ...
1987 Closes the scope of any preceding in-line macro.
1988 When used after physical formatting macros like
1992 switches back to the standard font face and weight.
1993 Can also be used to embed plain text strings in macro lines
1994 using semantic annotation macros.
1997 .Dl ".Em italic , Sy bold , No and roman"
1998 .Bd -literal -offset indent
2000 \&.Cm :C No / Ar pattern No / Ar replacement No /
2011 Suppress a space between the output of the preceding macro
2012 and the following text or macro.
2013 Following invocation, input is interpreted as normal text
2018 This has no effect when invoked at the start of a macro line.
2021 .Dl ".Ar name Ns = Ns Ar value"
2022 .Dl ".Cm :M Ns Ar pattern"
2023 .Dl ".Fl o Ns Ar output"
2030 .It Ic \&Nx Op Ar version
2033 version provided as an argument, or a default value if
2034 no argument is provided.
2052 .It Ic \&Oo Ar block
2053 Multi-line version of
2057 .Bd -literal -offset indent -compact
2059 \&.Op Fl flag Ns Ar value
2064 Optional part of a command line.
2065 Prints the argument(s) in brackets.
2066 This is most often used in the
2068 section of section 1 and 8 manual pages.
2071 .Dl \&.Op \&Fl a \&Ar b
2072 .Dl \&.Op \&Ar a | b
2077 .It Ic \&Os Op Ar system Op Ar version
2078 Operating system version for display in the page footer.
2079 This is the mandatory third macro of
2086 parameter specifies the relevant operating system or environment.
2087 It is suggested to leave it unspecified, in which case
2091 argument or, if that isn't specified either,
2100 .Dl \&.Os KTH/CSC/TCS
2107 .It Ic \&Ot Ar functype
2108 This macro is obsolete.
2113 both have the same effect.
2117 packages described it as
2118 .Dq "old function type (FORTRAN)" .
2120 .It Ic \&Ox Op Ar version
2123 version provided as an argument, or a default value
2124 if no argument is provided.
2139 .It Ic \&Pa Ar name ...
2140 An absolute or relative file system path, or a file or directory name.
2141 If an argument is not provided, the character
2143 is used as a default.
2146 .Dl \&.Pa /usr/bin/mandoc
2147 .Dl \&.Pa /usr/share/man/man7/mdoc.7
2152 Close parenthesised context opened by
2155 .It Ic \&Pf Ar prefix macro Op Ar argument ...
2156 Removes the space between its argument and the following macro.
2157 It is equivalent to:
2159 .D1 Ic \&No Pf \e& Ar prefix Ic \&Ns Ar macro Op Ar argument ...
2163 argument is not parsed for macro names or delimiters,
2164 but used verbatim as if it were escaped.
2167 .Dl ".Pf $ Ar variable_name"
2168 .Dl ".Pf . Ar macro_name"
2169 .Dl ".Pf 0x Ar hex_digits"
2175 .It Ic \&Po Ar block
2176 Multi-line version of
2181 This will assert vertical space between prior and subsequent macros
2184 Paragraph breaks are not needed before or after
2188 macros or before displays
2197 Parenthesised enclosure.
2202 Close quoted context opened by
2206 In-line literal display.
2207 This can be used for complete command invocations and for multi-word
2208 code examples when an indented display is not desired.
2215 .It Ic \&Qo Ar block
2216 Multi-line version of
2220 Encloses its arguments in
2235 Does not have any tail arguments.
2238 Begin a bibliographic
2241 Does not have any head arguments.
2242 The block macro may only contain
2258 child macros (at least one must be specified).
2261 .Bd -literal -offset indent -compact
2263 \&.%A J. E. Hopcroft
2265 \&.%B Introduction to Automata Theory, Languages, and Computation
2266 \&.%I Addison-Wesley
2267 \&.%C Reading, Massachusetts
2274 block is used within a SEE ALSO section, a vertical space is asserted
2275 before the rendered output, else the block continues on the current
2278 .It Ic \&Rv Fl std Op Ar function ...
2279 Insert a standard sentence regarding a function call's return value of 0
2280 on success and \-1 on error, with the
2282 libc global variable set on error.
2286 is not specified, the document's name set by
2291 arguments are treated as separate functions.
2296 Close single-quoted context opened by
2299 .It Ic \&Sh Ar TITLE LINE
2300 Begin a new section.
2301 For a list of conventional manual sections, see
2302 .Sx MANUAL STRUCTURE .
2303 These sections should be used unless it's absolutely necessary that
2304 custom sections be used.
2306 Section names should be unique so that they may be keyed by
2308 Although this macro is parsed, it should not consist of child node or it
2309 may not be linked with
2318 .It Ic \&Sm Op Cm on | off
2319 Switches the spacing mode for output generated from macros.
2321 By default, spacing is
2325 no white space is inserted between macro arguments and between the
2326 output generated from adjacent macros, but text lines
2327 still get normal spacing between words and sentences.
2329 When called without an argument, the
2331 macro toggles the spacing mode.
2332 Using this is not recommended because it makes the code harder to read.
2333 .It Ic \&So Ar block
2334 Multi-line version of
2338 Encloses its arguments in
2348 .It Ic \&Ss Ar Title line
2349 Begin a new subsection.
2352 there is no convention for the naming of subsections.
2355 the conventional sections described in
2356 .Sx MANUAL STRUCTURE
2357 rarely have subsections.
2359 Sub-section names should be unique so that they may be keyed by
2361 Although this macro is parsed, it should not consist of child node or it
2362 may not be linked with
2371 .It Ic \&St Fl Ns Ar abbreviation
2372 Replace an abbreviation for a standard with the full form.
2373 The following standards are recognised.
2374 Where multiple lines are given without a blank line in between,
2375 they all refer to the same standard, and using the first form
2378 .It C language standards
2380 .Bl -tag -width "-p1003.1g-2000" -compact
2390 The original C standard.
2404 The second major version of the C language standard.
2409 The third major version of the C language standard.
2411 .It POSIX.1 before the Single UNIX Specification
2413 .Bl -tag -width "-p1003.1g-2000" -compact
2419 The original POSIX standard, based on ANSI C.
2426 The first update of POSIX.1.
2433 Real-time extensions.
2438 POSIX thread interfaces.
2443 Technical Corrigendum.
2450 Includes POSIX.1-1990, 1b, 1c, and 1i.
2452 .It X/Open Portability Guide version 4 and related standards
2454 .Bl -tag -width "-p1003.1g-2000" -compact
2458 An XPG4 precursor, published in 1989.
2477 Based on POSIX.1 and POSIX.2, published in 1992.
2479 .It Single UNIX Specification version 1 and related standards
2481 .Bl -tag -width "-p1003.1g-2000" -compact
2487 This standard was published in 1994.
2488 It was used as the basis for UNIX 95 certification.
2489 The following three refer to parts of it.
2500 Networking APIs, including sockets.
2507 .It Single UNIX Specification version 2 and related standards
2509 .Bl -tag -width "-p1003.1g-2000" -compact
2512 This Standard was published in 1997
2513 and is also called X/Open Portability Guide version 5.
2514 It was used as the basis for UNIX 98 certification.
2515 The following refer to parts of it.
2531 .It Single UNIX Specification version 3
2533 .Bl -tag -width "-p1003.1-2001" -compact
2539 This standard is based on C99, SUSv2, POSIX.1-1996, 1d, and 1j.
2540 It is also called X/Open Portability Guide version 6.
2541 It is used as the basis for UNIX 03 certification.
2546 The second and last Technical Corrigendum.
2548 .It Single UNIX Specification version 4
2550 .Bl -tag -width "-p1003.1g-2000" -compact
2556 This standard is also called
2557 X/Open Portability Guide version 7.
2561 .Bl -tag -width "-p1003.1g-2000" -compact
2565 Floating-point arithmetic.
2570 Representation of dates and times, published in 1988.
2575 Ethernet local area networks.
2582 .It Ic \&Sx Ar Title line
2583 Reference a section or subsection in the same manual page.
2584 The referenced section or subsection name must be identical to the
2585 enclosed argument, including whitespace.
2588 .Dl \&.Sx MANUAL STRUCTURE
2595 .It Ic \&Sy Ar word ...
2596 Request a boldface font.
2598 This is most often used to indicate importance or seriousness (not to be
2599 confused with stress emphasis, see
2601 When none of the semantic macros fit, it is also adequate for syntax
2602 elements that have to be given or that appear verbatim.
2605 .Bd -literal -compact -offset indent
2609 appears in the owner permissions, set-user-ID mode is set.
2610 This utility replaces the former
2622 Table cell separator in
2624 lists; can only be used below
2627 .It Ic \&Tg Op Ar term
2628 Announce that the next input line starts a definition of the
2630 This macro must appear alone on its own input line.
2631 The argument defaults to the first argument of the first macro
2633 The argument may not contain whitespace characters, not even when it is quoted.
2636 extension and is typically ignored by other formatters.
2638 When viewing terminal output with
2642 command can be used to go to the definition of the
2644 as described for the
2648 when producing HTML output, a fragment identifier
2649 .Pq Ic id No attribute
2650 is generated, to be used for deep linking to this place of the document.
2652 In most cases, adding a
2654 macro would be redundant because
2656 is able to automatically tag most definitions.
2657 This macro is intended for cases where automatic tagging of a
2659 is unsatisfactory, for example if a definition is not tagged
2660 automatically (false negative) or if places are tagged that do
2664 When there is at least one
2668 no other places are automatically marked as definitions of that
2670 .It Ic \&Tn Ar word ...
2671 Supported only for compatibility, do not use this in new manuals.
2672 Even though the macro name
2674 suggests a semantic function, historic usage is inconsistent, mostly
2675 using it as a presentation-level macro to request a small caps font.
2677 Supported only for compatibility, do not use this in new manuals.
2679 .Dq currently under development.
2681 Supported only for compatibility, do not use this in new manuals.
2685 .It Ic \&Va Oo Ar type Oc Ar identifier ...
2690 .Dl \&.Va const char *bar ;
2692 For function arguments and parameters, use
2695 For declarations of global variables in the
2700 .It Ic \&Vt Ar type Op Ar identifier
2703 This is also used for indicating global variables in the
2705 section, in which case a variable name is also specified.
2706 Note that it accepts
2707 .Sx Block partial-implicit
2708 syntax when invoked as the first macro on an input line in the
2710 section, else it accepts ordinary
2713 In the former case, this macro starts a new output line,
2714 and a blank line is inserted in front if there is a preceding
2715 function definition or include directive.
2718 .Dl \&.Vt unsigned char
2719 .Dl \&.Vt extern const char * const sys_signame[] \&;
2721 For parameters in function prototypes, use
2723 instead, for function return types
2725 and for variable names outside the
2729 even when including a type with the name.
2731 .Sx MANUAL STRUCTURE .
2733 Close a scope opened by
2735 .It Ic \&Xo Ar block
2736 Extend the header of an
2738 macro or the body of a partial-implicit block macro
2739 beyond the end of the input line.
2740 This macro originally existed to work around the 9-argument limit
2744 .It Ic \&Xr Ar name section
2745 Link to another manual
2746 .Pq Qq cross-reference .
2752 number of another man page.
2756 .Dl \&.Xr mandoc 1 \&;
2757 .Dl \&.Xr mandoc 1 \&Ns s behaviour
2760 The syntax of a macro depends on its classification.
2763 refers to macro arguments, which may be followed by zero or more
2767 opens the scope of a macro; and if specified,
2773 column indicates that the macro may also be called by passing its name
2774 as an argument to another macro.
2776 .Sq \&.Op \&Fl O \&Ar file
2778 .Sq Op Fl O Ar file .
2779 To prevent a macro call and render the macro name literally,
2780 escape it by prepending a zero-width space,
2786 If a macro is not callable but its name appears as an argument
2787 to another macro, it is interpreted as opaque text.
2795 column indicates whether the macro may call other macros by receiving
2796 their names as arguments.
2797 If a macro is not parsed but the name of another macro appears
2798 as an argument, it is interpreted as opaque text.
2802 column, if applicable, describes closure rules.
2803 .Ss Block full-explicit
2804 Multi-line scope closed by an explicit closing macro.
2805 All macros contains bodies; only
2811 .Bd -literal -offset indent
2812 \&.Yo \(lB\-arg \(lBparm...\(rB\(rB \(lBhead...\(rB
2816 .Bl -column "MacroX" "CallableX" "ParsedX" "closed by XXX" -offset indent
2817 .It Em Macro Ta Em Callable Ta Em Parsed Ta Em Scope
2818 .It Ic \&Bd Ta \&No Ta \&No Ta closed by Ic \&Ed
2819 .It Ic \&Bf Ta \&No Ta \&No Ta closed by Ic \&Ef
2820 .It Ic \&Bk Ta \&No Ta \&No Ta closed by Ic \&Ek
2821 .It Ic \&Bl Ta \&No Ta \&No Ta closed by Ic \&El
2822 .It Ic \&Ed Ta \&No Ta \&No Ta opened by Ic \&Bd
2823 .It Ic \&Ef Ta \&No Ta \&No Ta opened by Ic \&Bf
2824 .It Ic \&Ek Ta \&No Ta \&No Ta opened by Ic \&Bk
2825 .It Ic \&El Ta \&No Ta \&No Ta opened by Ic \&Bl
2827 .Ss Block full-implicit
2828 Multi-line scope closed by end-of-file or implicitly by another macro.
2829 All macros have bodies; some
2831 .Ic \&It Fl bullet ,
2837 don't have heads; only one
2844 .Bd -literal -offset indent
2845 \&.Yo \(lB\-arg \(lBparm...\(rB\(rB \(lBhead... \(lBTa head...\(rB\(rB
2848 .Bl -column "MacroX" "CallableX" "ParsedX" "closed by XXXXXXXXXXX" -offset indent
2849 .It Em Macro Ta Em Callable Ta Em Parsed Ta Em Scope
2850 .It Ic \&It Ta \&No Ta Yes Ta closed by Ic \&It , Ic \&El
2851 .It Ic \&Nd Ta \&No Ta \&No Ta closed by Ic \&Sh
2852 .It Ic \&Nm Ta \&No Ta Yes Ta closed by Ic \&Nm , Ic \&Sh , Ic \&Ss
2853 .It Ic \&Sh Ta \&No Ta Yes Ta closed by Ic \&Sh
2854 .It Ic \&Ss Ta \&No Ta Yes Ta closed by Ic \&Sh , Ic \&Ss
2860 .Sx Block full-implicit
2861 macro only when invoked as the first macro
2864 section line, else it is
2866 .Ss Block partial-explicit
2867 Like block full-explicit, but also with single-line scope.
2868 Each has at least a body and, in limited circumstances, a head
2875 .Bd -literal -offset indent
2876 \&.Yo \(lB\-arg \(lBparm...\(rB\(rB \(lBhead...\(rB
2878 \&.Yc \(lBtail...\(rB
2880 \&.Yo \(lB\-arg \(lBparm...\(rB\(rB \(lBhead...\(rB \
2881 \(lBbody...\(rB \&Yc \(lBtail...\(rB
2883 .Bl -column "MacroX" "CallableX" "ParsedX" "closed by XXXX" -offset indent
2884 .It Em Macro Ta Em Callable Ta Em Parsed Ta Em Scope
2885 .It Ic \&Ac Ta Yes Ta Yes Ta opened by Ic \&Ao
2886 .It Ic \&Ao Ta Yes Ta Yes Ta closed by Ic \&Ac
2887 .It Ic \&Bc Ta Yes Ta Yes Ta closed by Ic \&Bo
2888 .It Ic \&Bo Ta Yes Ta Yes Ta opened by Ic \&Bc
2889 .It Ic \&Brc Ta Yes Ta Yes Ta opened by Ic \&Bro
2890 .It Ic \&Bro Ta Yes Ta Yes Ta closed by Ic \&Brc
2891 .It Ic \&Dc Ta Yes Ta Yes Ta opened by Ic \&Do
2892 .It Ic \&Do Ta Yes Ta Yes Ta closed by Ic \&Dc
2893 .It Ic \&Ec Ta Yes Ta Yes Ta opened by Ic \&Eo
2894 .It Ic \&Eo Ta Yes Ta Yes Ta closed by Ic \&Ec
2895 .It Ic \&Fc Ta Yes Ta Yes Ta opened by Ic \&Fo
2896 .It Ic \&Fo Ta \&No Ta \&No Ta closed by Ic \&Fc
2897 .It Ic \&Oc Ta Yes Ta Yes Ta closed by Ic \&Oo
2898 .It Ic \&Oo Ta Yes Ta Yes Ta opened by Ic \&Oc
2899 .It Ic \&Pc Ta Yes Ta Yes Ta closed by Ic \&Po
2900 .It Ic \&Po Ta Yes Ta Yes Ta opened by Ic \&Pc
2901 .It Ic \&Qc Ta Yes Ta Yes Ta opened by Ic \&Oo
2902 .It Ic \&Qo Ta Yes Ta Yes Ta closed by Ic \&Oc
2903 .It Ic \&Re Ta \&No Ta \&No Ta opened by Ic \&Rs
2904 .It Ic \&Rs Ta \&No Ta \&No Ta closed by Ic \&Re
2905 .It Ic \&Sc Ta Yes Ta Yes Ta opened by Ic \&So
2906 .It Ic \&So Ta Yes Ta Yes Ta closed by Ic \&Sc
2907 .It Ic \&Xc Ta Yes Ta Yes Ta opened by Ic \&Xo
2908 .It Ic \&Xo Ta Yes Ta Yes Ta closed by Ic \&Xc
2910 .Ss Block partial-implicit
2911 Like block full-implicit, but with single-line scope closed by the
2913 .Bd -literal -offset indent
2914 \&.Yo \(lB\-arg \(lBval...\(rB\(rB \(lBbody...\(rB \(lBres...\(rB
2916 .Bl -column "MacroX" "CallableX" "ParsedX" -offset indent
2917 .It Em Macro Ta Em Callable Ta Em Parsed
2918 .It Ic \&Aq Ta Yes Ta Yes
2919 .It Ic \&Bq Ta Yes Ta Yes
2920 .It Ic \&Brq Ta Yes Ta Yes
2921 .It Ic \&D1 Ta \&No Ta \&Yes
2922 .It Ic \&Dl Ta \&No Ta Yes
2923 .It Ic \&Dq Ta Yes Ta Yes
2924 .It Ic \&En Ta Yes Ta Yes
2925 .It Ic \&Op Ta Yes Ta Yes
2926 .It Ic \&Pq Ta Yes Ta Yes
2927 .It Ic \&Ql Ta Yes Ta Yes
2928 .It Ic \&Qq Ta Yes Ta Yes
2929 .It Ic \&Sq Ta Yes Ta Yes
2930 .It Ic \&Vt Ta Yes Ta Yes
2936 .Sx Block partial-implicit
2937 only when invoked as the first macro
2940 section line, else it is
2942 .Ss Special block macro
2945 macro can only be used below
2950 It delimits blocks representing table cells;
2951 these blocks have bodies, but no heads.
2952 .Bl -column "MacroX" "CallableX" "ParsedX" "closed by XXXX" -offset indent
2953 .It Em Macro Ta Em Callable Ta Em Parsed Ta Em Scope
2954 .It Ic \&Ta Ta Yes Ta Yes Ta closed by Ic \&Ta , Ic \&It
2957 Closed by the end of the line, fixed argument lengths,
2958 and/or subsequent macros.
2959 In-line macros have only text children.
2960 If a number (or inequality) of arguments is
2962 then the macro accepts an arbitrary number of arguments.
2963 .Bd -literal -offset indent
2964 \&.Yo \(lB\-arg \(lBval...\(rB\(rB \(lBargs...\(rB \(lBres...\(rB
2966 \&.Yo \(lB\-arg \(lBval...\(rB\(rB \(lBargs...\(rB Yc...
2968 \&.Yo \(lB\-arg \(lBval...\(rB\(rB arg0 arg1 argN
2970 .Bl -column "MacroX" "CallableX" "ParsedX" "Arguments" -offset indent
2971 .It Em Macro Ta Em Callable Ta Em Parsed Ta Em Arguments
2972 .It Ic \&%A Ta \&No Ta \&No Ta >0
2973 .It Ic \&%B Ta \&No Ta \&No Ta >0
2974 .It Ic \&%C Ta \&No Ta \&No Ta >0
2975 .It Ic \&%D Ta \&No Ta \&No Ta >0
2976 .It Ic \&%I Ta \&No Ta \&No Ta >0
2977 .It Ic \&%J Ta \&No Ta \&No Ta >0
2978 .It Ic \&%N Ta \&No Ta \&No Ta >0
2979 .It Ic \&%O Ta \&No Ta \&No Ta >0
2980 .It Ic \&%P Ta \&No Ta \&No Ta >0
2981 .It Ic \&%Q Ta \&No Ta \&No Ta >0
2982 .It Ic \&%R Ta \&No Ta \&No Ta >0
2983 .It Ic \&%T Ta \&No Ta \&No Ta >0
2984 .It Ic \&%U Ta \&No Ta \&No Ta >0
2985 .It Ic \&%V Ta \&No Ta \&No Ta >0
2986 .It Ic \&Ad Ta Yes Ta Yes Ta >0
2987 .It Ic \&An Ta Yes Ta Yes Ta >0
2988 .It Ic \&Ap Ta Yes Ta Yes Ta 0
2989 .It Ic \&Ar Ta Yes Ta Yes Ta n
2990 .It Ic \&At Ta Yes Ta Yes Ta 1
2991 .It Ic \&Bsx Ta Yes Ta Yes Ta n
2992 .It Ic \&Bt Ta \&No Ta \&No Ta 0
2993 .It Ic \&Bx Ta Yes Ta Yes Ta n
2994 .It Ic \&Cd Ta Yes Ta Yes Ta >0
2995 .It Ic \&Cm Ta Yes Ta Yes Ta >0
2996 .It Ic \&Db Ta \&No Ta \&No Ta 1
2997 .It Ic \&Dd Ta \&No Ta \&No Ta n
2998 .It Ic \&Dt Ta \&No Ta \&No Ta n
2999 .It Ic \&Dv Ta Yes Ta Yes Ta >0
3000 .It Ic \&Dx Ta Yes Ta Yes Ta n
3001 .It Ic \&Em Ta Yes Ta Yes Ta >0
3002 .It Ic \&Er Ta Yes Ta Yes Ta >0
3003 .It Ic \&Es Ta Yes Ta Yes Ta 2
3004 .It Ic \&Ev Ta Yes Ta Yes Ta >0
3005 .It Ic \&Ex Ta \&No Ta \&No Ta n
3006 .It Ic \&Fa Ta Yes Ta Yes Ta >0
3007 .It Ic \&Fd Ta \&No Ta \&No Ta >0
3008 .It Ic \&Fl Ta Yes Ta Yes Ta n
3009 .It Ic \&Fn Ta Yes Ta Yes Ta >0
3010 .It Ic \&Fr Ta Yes Ta Yes Ta >0
3011 .It Ic \&Ft Ta Yes Ta Yes Ta >0
3012 .It Ic \&Fx Ta Yes Ta Yes Ta n
3013 .It Ic \&Hf Ta \&No Ta \&No Ta n
3014 .It Ic \&Ic Ta Yes Ta Yes Ta >0
3015 .It Ic \&In Ta \&No Ta \&No Ta 1
3016 .It Ic \&Lb Ta \&No Ta \&No Ta 1
3017 .It Ic \&Li Ta Yes Ta Yes Ta >0
3018 .It Ic \&Lk Ta Yes Ta Yes Ta >0
3019 .It Ic \&Lp Ta \&No Ta \&No Ta 0
3020 .It Ic \&Ms Ta Yes Ta Yes Ta >0
3021 .It Ic \&Mt Ta Yes Ta Yes Ta >0
3022 .It Ic \&Nm Ta Yes Ta Yes Ta n
3023 .It Ic \&No Ta Yes Ta Yes Ta >0
3024 .It Ic \&Ns Ta Yes Ta Yes Ta 0
3025 .It Ic \&Nx Ta Yes Ta Yes Ta n
3026 .It Ic \&Os Ta \&No Ta \&No Ta n
3027 .It Ic \&Ot Ta Yes Ta Yes Ta >0
3028 .It Ic \&Ox Ta Yes Ta Yes Ta n
3029 .It Ic \&Pa Ta Yes Ta Yes Ta n
3030 .It Ic \&Pf Ta Yes Ta Yes Ta 1
3031 .It Ic \&Pp Ta \&No Ta \&No Ta 0
3032 .It Ic \&Rv Ta \&No Ta \&No Ta n
3033 .It Ic \&Sm Ta \&No Ta \&No Ta <2
3034 .It Ic \&St Ta \&No Ta Yes Ta 1
3035 .It Ic \&Sx Ta Yes Ta Yes Ta >0
3036 .It Ic \&Sy Ta Yes Ta Yes Ta >0
3037 .It Ic \&Tg Ta \&No Ta \&No Ta <2
3038 .It Ic \&Tn Ta Yes Ta Yes Ta >0
3039 .It Ic \&Ud Ta \&No Ta \&No Ta 0
3040 .It Ic \&Ux Ta Yes Ta Yes Ta n
3041 .It Ic \&Va Ta Yes Ta Yes Ta n
3042 .It Ic \&Vt Ta Yes Ta Yes Ta >0
3043 .It Ic \&Xr Ta Yes Ta Yes Ta 2
3046 When a macro argument consists of one single input character
3047 considered as a delimiter, the argument gets special handling.
3048 This does not apply when delimiters appear in arguments containing
3049 more than one character.
3050 Consequently, to prevent special handling and just handle it
3051 like any other argument, a delimiter can be escaped by prepending
3054 In text lines, delimiters never need escaping, but may be used
3055 as normal punctuation.
3057 For many macros, when the leading arguments are opening delimiters,
3058 these delimiters are put before the macro scope,
3059 and when the trailing arguments are closing delimiters,
3060 these delimiters are put after the macro scope.
3061 Spacing is suppressed after opening delimiters
3062 and before closing delimiters.
3065 .D1 Pf \. \&Aq "( [ word ] ) ."
3069 .D1 Aq ( [ word ] ) .
3071 Opening delimiters are:
3073 .Bl -tag -width Ds -offset indent -compact
3080 Closing delimiters are:
3082 .Bl -tag -width Ds -offset indent -compact
3101 Note that even a period preceded by a backslash
3103 gets this special handling; use
3107 Many in-line macros interrupt their scope when they encounter
3108 delimiters, and resume their scope when more arguments follow that
3112 .D1 Pf \. \&Fl "a ( b | c \e*(Ba d ) e"
3116 .D1 Fl a ( b | c \*(Ba d ) e
3118 This applies to both opening and closing delimiters,
3119 and also to the middle delimiter, which does not suppress spacing:
3121 .Bl -tag -width Ds -offset indent -compact
3126 As a special case, the predefined string \e*(Ba is handled and rendered
3127 in the same way as a plain
3130 Using this predefined string is not recommended in new manuals.
3132 Appending a zero-width space
3134 to the end of an input line is also useful to prevent the interpretation
3135 of a trailing period, exclamation or question mark as the end of a
3136 sentence, for example when an abbreviation happens to occur
3137 at the end of a text or macro input line.
3141 documents, usage of semantic markup is recommended in order to have
3142 proper fonts automatically selected; only when no fitting semantic markup
3143 is available, consider falling back to
3150 font mode, it will automatically restore the previous font when exiting
3152 Manually switching the font using the
3155 font escape sequences is never required.
3157 This section provides an incomplete list of compatibility issues
3158 between mandoc and GNU troff
3161 The following problematic behaviour is found in groff:
3166 does not format its arguments when used in the FILES section under
3170 can only be called by other macros, but not at the beginning of a line.
3176 .Pq font family face
3178 escapes behave irregularly when specified within line-macro scopes.
3180 Negative scaling units return to prior lines.
3181 Instead, mandoc truncates them to zero.
3184 The following features are unimplemented in mandoc:
3188 .Ic \&Bd Fl file Ar file
3189 is unsupported for security reasons.
3193 does not adjust the right margin, but is an alias for
3199 does not use a literal font, but is an alias for
3204 .Fl offset Cm center
3208 Groff does not implement centered and flush-right rendering either,
3209 but produces large indentations.
3221 .Lk https://mandoc.bsd.lv/mdoc/ "extended documentation for the mdoc language"
3222 provides a few tutorial-style pages for beginners, an extensive style
3223 guide for advanced authors, and an alphabetic index helping to choose
3224 the best macros for various kinds of content.
3227 .Lk https://man.voidlinux.org/groff_mdoc "groff_mdoc(7)"
3230 package documents exactly the same language in a somewhat different style.
3234 language first appeared as a troff macro package in
3236 It was later significantly updated by Werner Lemberg and Ruslan Ermilov
3238 The standalone implementation that is part of the
3240 utility written by Kristaps Dzonsons appeared in
3245 reference was written by
3246 .An Kristaps Dzonsons Aq Mt kristaps@bsd.lv .