from small one page howto to huge articles all in one place
Last additions:
May 25th. 2007:
April, 26th. 2006:
|
You are here: manpages
groff_mm
Section: Environments, Tables, and Troff Macros (7) Updated: 2 July 2023 Index
Return to Main Contents
Name
groff_mm - memorandum macros for GNU
roff
.nr d-fallback 1
.nr d-fallback 1
Synopsis
[ option~...]
[ file~...]
[ option~...]
[ file~...]
Description
The GNU implementation of the
mm
macro package is part of the
groff
document formatting system.
The
mm
package is suitable for the composition of
letters,
memoranda,
reports,
and books.
Call an
mm
macro at the beginning of a document to initialize the package.
A simple
mm
document might use only
P
for paragraphing.
Set numbered and unnumbered section headings with
H
and
HU,
respectively.
Change the style of the typeface with
B,
I,
and
R;
you can alternate styles with
BI,
BR,
IB,
IR,
RB,
and
RI.
Several nestable list types are available via
AL,
BL,
BVL,
DL,
ML,
RL,
and
VL;
each of these begins a list,
to which
LI
adds an item and
LE
ends the (nested) list.
Customized list arrangements are supported by
LB.
DS
and
DF
start static and floating displays,
respectively;
either is terminated with
DE.
groff mm
is intended to be compatible with the
mm
implementation found in the AT&T Documenter's Workbench (DWB),
with the following limitations.
- [bu]
-
Omitted features include
the logo and company name strings,
}Z
and
]S,
respectively;
the encoded company site location addresses recognized as the third
argument to the
AU
macro;
the
Pv
([lq]private[rq] heading)
register;
and the
OK
(other keywords),
and
PM
(proprietary markings)
macros.
- [bu]
-
The
CS
(output cover sheet)
macro is implemented only for memorandum type 4.
- [bu]
-
The
grap
preprocessor is not explicitly supported;
no
G1
and
G2
macros
are defined.
- [bu]
-
The registers
A,
C,
E,
T,
and
U,
typically set from the
troff or
nroff command lines with DWB
mm,
are not recognized.
- [bu]
-
When setting the registers
L
or
W
from the command line,
use an explicit scaling unit to avoid surprises.
- [bu]
-
DWB
mm's
nP
macro indented the second line of a paragraph to align it with the start
of the text of the first
(after the paragraph number);
groff mm's
does not.
- [bu]
-
Cut marks are not supported.
DWB
mm
supported only seven levels of heading.
As a compatible extension,
groff mm
supports fourteen,
introducing new registers
H8
through
H14,
and affecting the interpretation of the
HF
and
HP
strings.
Macro,
register,
and string descriptions in this page frequently mention each other;
most cross references are to macros.
Where a register or string is referenced,
its type is explicitly identified.
mm's
macro names are usually in full capitals;
registers and strings tend to have mixe-case names.
Document styles
groff mm
offers three different frameworks for document organization.
COVER/: COVEND
is a flexible means of preparing any document requiring a cover page.
LT/ LO
aids preparation of typical Anglophone correspondence
(business letters,
for example).
The
MT
memorandum type mechanism implements a group of formal styles
historically used by AT&T Bell Laboratories.
Your document can select at most one of these approaches;
when used,
each disables the others.
Localization
groff mm
is designed to be easily localized.
For languages other than English,
strings that can appear in output are collected in the file
/usr/:share/:groff/:1.23.0/:tmac/:xx :.tmac,
where
xx
is an ISO~639 tw-letter language identifier.
Localization packages should be loaded after
mm;
for example,
you might format a Swedish
mm
document with the command
[lq] groff -mm -msv[rq].
This package can also be localized by site or territory;
for example,
/usr/:share/:groff/:1.23.0/:tmac/:mse:.tmac
illustrates how to adapt the output to a national standard using its ISO
3166 territory code.
Such a package can define a string that causes a macro file
/usr/:share/:groff/:1.23.0/:tmac/:mm/:territory _locale
to be loaded at package initialization.
If this mechanism is not used,
/usr/:share/:groff/:1.23.0/:tmac/:mm/:locale
is loaded instead.
No diagnostic is produced if these files do not exist.
Registers and strings
Much
mm
behavior can be configured by registers and strings.
A register is assigned with the
nr
request.
-
.nr
ident
[[-]]n
[i]
ident
is the name of the register,
and
n~is
the value to be assigned.
n~can
be prefixed with a plus or minus sign if incrementation or
decrementation (respectively) of the register's existing value
by~ n
is desired.
If assignment of a (possibly) negative
n~is
required,
further prefix it with a zero or enclose it in parentheses.
If
i~is
specified,
the register is automatically modified
by ~i
prior to interpolation if a plus or minus sign is included in the escape
sequence as follows.
-
[rs]n[[-]][ident]
i~can
be negative;
it combines algebraically with the sign in the interpolation escape
sequence.
Strings are defined with the
ds
request.
-
.ds
ident contents
contents
consumes everything up to the end of the line,
including trailing spaces.
It is a good practice to end
contents
with a comment escape sequence
( [rs][dq])
so that extraneous spaces do not intrude during document maintenance.
To include leading spaces in
contents,
prefix it with a double quote.
Strings are interpolated with the
[rs]*
escape sequence.
-
[rs]*[ident]
Register and string name spaces are distinct,
but strings and macros share a name space.
Defining a string with the same name as an
mm
macro is not supported and may cause incorrect rendering,
the emission of diagnostic messages,
and an error exit status from
troff.
Register format
A register is interpolated using Arabic numerals if no other format has
been assigned to it.
Assign a format to a register with the
af
request.
-
.af~R c
R~is
the name of the register,
and
c~is
the format.
If
c~is
a sequence of Arabic numerals,
their quantity defines a zer-padded minimum width for the interpolated
register value.
-
| Form | Sequence
|
| 1 | 0, 1, 2, 3, ..., 10, ...
|
| 001 | 000, 001, 002, 003, ..., 1000, ...
|
| i | 0, i, ii, iii, iv, ...
|
| I | 0, I, II, III, IV, ...
|
| a | 0, a, b, c, ..., z, aa, ab, ...
|
| A | 0, A, B, C, ..., Z, AA, AB, ...
|
Fonts
In
groff mm,
the fonts
(or rather,
font styles)
R~(roman),
I~(italic),
and
B~(bold)
are mounted at font positions
1,
2,
and~ 3,
respectively.
Internally,
font positions are used for backward compatibility.
From a practical point of view,
it doesn't make a big difference[em]a different font family can still
be selected by invoking
groff's
fam
request or using its
-f
comman-line option.
On the other hand,
if you want to replace just,
for example,
font~ I
with Zapf Chancery Medium italic
(available on
groff's
pdf
and
ps
output devices),
you have to use the
fp
request,
replacing the font at position~2 with
[lq] .fp~2~ZCMI[rq]).
Because the cover sheet,
memorandum type,
and
integration macros explicitly request fonts named
B,
I,
and
R,
you will also need to remap these font names with the
ftr
request,
for instance with
[lq] .ftr~I~ZCMI[rq].
Macros
An explicitly empty argument may be specified with a pair of double
quotes;
to call a macro
XX
with an empty second argument but no-empty first and third ones,
you could input the following.
-
.XX foo [dq][dq] baz
Macro names longer than two characters are GNU extensions;
some shorter names were not part of DWB
mm's
published interface but are documented aspects of
groff mm.
- )E level text
-
Add heading text
text
to the table of contents with
level,
which is either~0 or in the range 1 to~7.
See also
H.
This undocumented DWB
mm
macro is exposed by
groff mm
to enable customized tables of contents.
- 1C~[1]
-
Format page text in one column.
The page is broken.
A~1
argument suppresses this break;
its use may cause body text and a pending footnote to overprint.
See
2C,
MC,
and
NCOL.
- 2C
-
Begin tw-column formatting.
This is a special case of
MC.
See
1C
and
NCOL.
- AE
-
Abstract end;
stop collecting abstract text.
See
AS.
- AF~[
-
fir-name]
Specify firm associated with the document.
At most one can be declared;
the firm name is used by memorandum types and available to cover sheets.
AF
terminates a document title started with
TL,
and can be called without an argument for that purpose.
See
MT
and
COVER.
- AL~[
-
type~[tex-indent~[1]]]
Begin an aut-incrementing numbered list.
Item numbers start at one.
The
type
argument assigns the register format
(see above)
of the list item enumerators.
The default
is~1.
An explicitly empty
type
also indicates the default.
A
tex-indent
argument overrides register
Li.
A third argument suppresses the blank line that normally precedes each
list item.
Use
LI
to declare list items,
and
LE
to end the list.
- APP~
-
[id~[title]]
Begin an appendix.
If the identifier
id
is omitted,
it is incremented
(or initialized,
if necessary).
The register format used for
id
is [lq]A[rq].
The page is broken.
The register
Aph
determines whether an appendix heading is then formatted.
This heading uses the string
App
followed by
id.
Appendices appear in any table of contents
(see
TC).
The string
Apptxt
is set to
title
if the latter is present,
and made empty otherwise.
- APPSK~id n~
-
[title]
As
APP,
but increment the page number by
n.
Use this macro to [lq]skip pages[rq] when diagrams or other materials
not formatted by
troff
are included in appendices.
- AS~[
-
placement~[indentation]]
Abstract start;
begin collecting abstract.
Input up to the next
AE
call is included in the abstract.
placement
influences the location of the abstract on the cover sheet of a
memorandum
(see
MT).
COVER,
by contrast,
ignores
placement
by default,
but can be customized to interpret it.
-
| placement | Effect
|
| 0 |
The abstract appears on page~1 and cover sheet if the document is a
[lq]released paper[rq] memorandum
([lq].MT 4[rq]);
otherwise,
it appears on page~1 without a cover sheet.
|
| 1 |
The abstract appears only on the cover sheet
([lq].MT 4[rq]
only).
|
-
An abstract does not appear at all in external letters
([lq].MT 5[rq]).
A~placement
of
2
was supported by DWB
mm
but is not by
groff mm.
-
A second argument increases the indentation by
indentation
and reduces the line length by twice this amount.
A scaling unit of ens is assumed.
The default is~0.
- AST~
-
[caption]
Set the caption above the abstract to
caption,
or clear it if there is no argument.
The default is [lq]ABSTRACT[rq].
- AT~title
-
~...
Specify author's title(s).
If present,
AT
must appear just after the corresponding author's
AU.
Each
title
occupies an output line beneath the author's name in the signature block
used by
LT
letters
(see
SG)
and in
MT
memoranda.
The
ms
cover sheet style also uses it.
- AU~
-
[name~[initials~[loc~[dept~[ext~[room~[arg1~[arg2~[arg3]]]]]]]]]
Specify author.
AU
terminates a document title started with
TL,
and can be called without arguments for that purpose.
Author information is used by cover sheets,
MT
memoranda,
and
SG.
Further arguments comprise
initials,
location,
department,
telephone extension,
room number or name,
and up to three additional items.
Repeat
AU
to identify multiple authors.
-
Use
WA/WE
instead to identify the author for documents employing
LT.
- AV~[
-
name~[1]]
Format approval lines for a handwritten signature and date.
Two horizontal rules are drawn,
with the specified
name
and the text of the string
Letdate
beneath them.
Above these rules,
the text in the string
Letapp
is formatted;
a second argument replaces this text with a blank line.
See
LT.
- AVL~[
-
name]
As
AV,
but the date,
date rule,
and approval notation
Letapp
are omitted.
- B~
-
[bol-text~[previou-fon-text]]~...
Join
bol-text
in boldface with
previou-fon-text
in the previous font,
without space between the arguments.
If no arguments,
switch font to bold style.
- B1
-
Begin boxed,
kept display.
The text is indented one character,
and the right margin is one character shorter.
This is a GNU extension.
- B2
-
End boxed,
kept display.
This is a GNU extension.
- BE
-
End bottom block; see
BS.
- BI~
-
[bol-text~[itali-text]]~...
Join
bol-text
in boldface with
itali-text
in italics,
without space between the arguments.
- BL~[
-
tex-indent~[1]]
Begin bulleted list.
Items are prefixed with a bullet and a space.
A
tex-indent
argument overrides register
Pi.
A second argument suppresses blank lines between items.
Use
LI
to declare list items,
and
LE
to end the list.
- BR~
-
[bol-text~[roma-text]]~...
Join
bol-text
in boldface with
roma-text
in roman style,
without space between the arguments.
- BS
-
Begin bottom block.
Input is collected until
BE
is called,
and output between the footnote area and footer of each page.
- BVL~[
-
tex-indent~[mar-indent~[1]]]
Begin broken variabl-item
(or [lq]tagged[rq])
list.
Each item is expected to supply its own mark.
The line is always broken after the mark;
contrast
VL.
tex-indent
sets the indentation of the text,
and
mar-indent
the distance from the current list indentation to the mark.
A third argument suppresses the blank line that normally precedes each
list item.
Use
LI
to declare list items,
and
LE
to end the list.
- COVER~
-
[style]
Begin a cover page description.
COVER
must appear before the body text
(or main matter)
of a document.
The argument
style
is used to construct the file name
/usr/:share/:groff/:1.23.0/:tmac/mm/:style:.cov
and load it with the
mso
request.
The default
style
is
ms;
the
ms.cov
file prepares a cover page resembling those of the
ms
package.
A
.cov
file must define a
COVEND
macro,
which a document must call at the end of the cover description.
Use cover description macros in the following order;
only
TL
and
AU
are required.
-
.COVER
.TL
.AF
.AU
.AT
.AS
.AE
.COVEND
- COVEND
-
End the cover description.
- DE
-
End static or floating display begun with
DS
or
DF.
- DF~[
-
format~[fill~[righ-indentation]]]
Begin floating display.
A floating display is saved in a queue and output in the order entered.
Arguments are handled as in
DS.
Floating displays cannot be nested.
Placement of floating displays is controlled by the registers
De
and
Df.
- DL~[
-
tex-indent~[1]]
Begin dashed list.
Items are prefixed with an em dash and a space.
A
tex-indent
argument overrides register
Pi.
A second argument suppresses blank lines between items.
Use
LI
to declare list items,
and
LE
to end the list.
- DS~[
-
format~[fill~[righ-indentation]]]
Begin static display.
Input until
DE
is called is collected into a display.
The display is output on a single page unless it is taller than the
height of the page.
DS
can be nested
(contrast with
DF).
-
| format | Effect
|
| I]none] | Do not indent the display.
|
| L | Do not indent the display.
|
| I |
Indent text by
[rs]n[Si].
|
| C | Center each line.
|
| CB | Center the whole display as a block.
|
| R | Righ-adjust the lines.
|
| RB | Righ-adjust the whole display as a block.
|
-
The values [lq]L[rq],
[lq]I[rq],
[lq]C[rq],
and [lq]CB[rq] can also be specified as [lq]0[rq],
[lq]1[rq],
[lq]2[rq],
and
[lq]3[rq],
respectively,
for compatibility with
DWB~mm.
-
| fill | Effect
|
| I]none] | Disable filling.
|
| N | Disable filling.
|
| F | Enable filling.
|
-
[lq]N[rq] and [lq]F[rq] can also be specified as [lq]0[rq] and
[lq]1[rq],
respectively,
for compatibility with
DWB~mm.
-
A third argument
reduces the line length by
righ-indentation.
-
mm
normally
places blank lines before and after the display.
Set register
Ds
to~0 to suppress these.
- EC~
-
[title~[override~[flag~[refname]]]]
Caption an equation.
The caption consists of the string
Liec
followed by an automatically incrementing counter stored in the register
Ec,
punctuation configured by the register
Of,
then
title
(if any).
Use the
af
request to configure
Ec's
number format.
override
and
flag
alter the equation number as follows.
Omitting
flag
and specifying
0
in its place are equivalent.
-
| flag | Effect
|
| 0 |
Prefix number with
override.
|
| 1 |
Suffix number with
override.
|
| 2 |
Replace number with
override.
|
-
Equation captions are centered irrespective of the alignment of any
enclosing display.
-
refname
stores the equation number using
SETR;
it can be retreived with
[lq].GETST
refname[rq].
This argument is a GNU extension.
-
Captioned equations are listed in a table of contents
(see
TC)
if the Boolean register
Le
is true.
Such a list uses the string
Le
as a heading.
- EF~[[dq][aq]
-
left[aq]center[aq]right[aq][dq]]
Define the eve-page footer,
which is formatted just above the normal page footer on eve-numbered
pages.
See
PF.
EF
defines the string
EOPef.
- EH~[[dq][aq]
-
left[aq]center[aq]right[aq][dq]]
Define the eve-page header,
which is formatted just below the normal page header on eve-numbered
pages.
See
PH.
EH
defines the string
TPeh.
- EN
-
End equation input preprocessed by
see
EQ.
- EOP
-
If defined,
this macro is called in lieu of normal page footer layout.
Headers and footers are formatted in a separate environment.
See
TP.
-
Strings available to EOP
|
|
| EOPf | argument to PF
|
| EOPef | argument to EF
|
| EOPof | argument to OF
|
- EPIC [-L] width height [name]
-
Draw a box with the given
width
and
height.
It also prints the text
name
or a default string if
name
is not specified.
This is used to include external pictures;
just give the size of the picture.
-L
lef-aligns the picture;
the default is to center.
See
PIC.
- EQ~[
-
label]
Start equation input preprocessed by
EQ
and
EN
macro calls bracket an equation region.
Such regions must be contained in displays
(DS/DE),
except when the region is used only to configure
eqn
and not to produce output.
If present,
label
appears aligned to the right and
centered vertically within the display;
see register
Eq.
If multiple
eqn regions occur within a display,
only the last
label
(if any)
is used.
- EX~
-
[title~[override~[flag~[refname]]]]
Caption an exhibit.
Arguments are handled analogously to
EC.
The register
Ex
is the exhibit counter.
The string
Liex
precedes the exhibit number and any
title.
Exhibit captions are centered irrespective of the alignment of any
enclosing display.
-
Captioned exhibits are listed in a table of contents
(see
TC)
if the Boolean register
Lx
is true.
Such a list uses the string
Lx
as a heading.
- FC~[
-
closin-text]
Output the string
Letfc,
or the specified
closin-text,
as the formal closing of a letter.
- FD~[
-
arg~[1]]
Configure display of footnotes.
The first argument encodes enablement of
automatic hyphenation,
adjustment to the right margin,
indentation of footnote text,
and lef- vs. righ-alignment of the footnote label within the space
allocated for it.
-
| arg | Hyphenate? | Adjust? | Indent? | Label alignment
|
| 0 | no | yes | yes | left
|
| 1 | yes | yes | yes | left
|
| 2 | no | no | yes | left
|
| 3 | yes | no | yes | left
|
| 4 | no | yes | no | left
|
| 5 | yes | yes | no | left
|
| 6 | no | no | no | left
|
| 7 | yes | no | no | left
|
| 8 | no | yes | yes | right
|
| 9 | yes | yes | yes | right
|
| 10 | no | no | yes | right
|
| 11 | yes | no | yes | right
|
-
An
arg
greater than 11 is treated
as~0.
mm's
default
is~0.
-
If a second argument,
conventionally
1,
is given,
footnote numbering is reset when a firs-level heading is encountered.
See
FS.
- FE
-
End footnote;
see
FS.
- FG~
-
[title~[override~[flag~[refname]]]]
Caption a figure.
Arguments are handled analogously to
EC.
The register
Fg
is the figure counter.
The string
Lifg
precedes the figure number and any
title.
Figure captions are centered irrespective of the alignment of any
enclosing display.
-
Captioned figures are listed in a table of contents
(see
TC)
if the Boolean register
Lf
is true.
Such a list uses the string
Lf
as a heading.
- FS~[
-
label]
Start footnote.
Input until
FE
is called is collected into a footnote.
By default,
footnotes are automatically numbered starting at 1;
the number is available in register
:p
and,
with a trailing period,
in
string~F.
This string precedes the footnote text at the bottom of the column or
page.
Footnotes are vertically separated by the product of
registers~Fs
and
Lsp.
In
groff mm,
footnotes may be used in displays.
-
A
label
argument replaces the contents of the string
F;
it need not be numeric.
In this event,
the footnote marker in the body text must be explicitly written.
- GETHN refname [varname]
-
Include the heading number where the corresponding
[lq].SETR
refname[rq]
was placed.
This is displayed as [lq]X.X.X.[rq] in pass~1.
See
INITR.
If
varname
is used,
GETHN
sets the string
varname
to the heading number.
- GETPN refname [varname]
-
Include the page number where the corresponding
[lq].SETR
refname[rq]
was placed.
This is displayed as [lq]9999[rq] in pass~1.
See
INITR.
If
varname
is used,
GETPN
sets the string
varname
to the page number.
- GETR refname
-
Combine
GETHN
and
GETPN
with the text [lq]chapter[rq] and [lq],~page[rq].
The string
Qrf
contains the text for the cross reference:
-
-
.ds Qrf See chapter [rs][rs]*[Qrfh], page [rs][rs]*[Qrfp].
-
Qrf
may be changed to support other languages.
Strings
Qrfh
and
Qrfp
are set by
GETR
and contain the page and heading number,
respectively.
- GETST refname [varname]
-
Include the string saved with the second argument to
.SETR.
This is a dummy string in pass~1.
If
varname
is used,
GETST
sets it to the saved string.
See
INITR.
- H~level~
-
[title~[suffix]]
Set a numbered section heading at
level.
mm
produces numbered
heading marks
of the form
a.b.c...,
with up to fourteen levels of nesting.
Each level's number increases automatically with each
H
call and is reset to zero when a more significant
level
is specified.
[lq]1[rq]~is
the most significant or coarsest division of the document.
Text after an
H
call is formatted as a paragraph;
calling
P
is unnecessary.
-
title
specifies an optional title;
it must be doubl-quoted if it contains spaces.
mm
appends
suffix
to
title
in the body of the document,
but omits it from any table of contents
(see
TC).
This facility can be used to annotate the heading title with a footnote.
suffix
should not interpolate
the~F
string;
specify a footnote mark explicitly.
See
FS.
-
Heading behavior is highly configurable.
Several registers set a
threshold,
where heading levels at or below the threshold value are handled in one
way,
and those above it another.
For example,
a heading level within the threshold of register
Cl
is included in the table of contents
(see
TC).
-
Heading layout.
Register
Ej
sets a threshold for page breaking (ejection) prior to a heading.
If not preceded by a page break,
a heading level below the threshold in register
Hps
is preceded by the amount of vertical space in register
Hps1,
and by the amount in
Hps2
otherwise.
The
Hb
register sets a threshold below which a break occurs after the heading,
and register
Hs
sets a threshold below which vertical space follows it.
If the heading level is not less than both of these,
a
ru-in heading
is produced;
paragraph text follows on the same output line.
Otherwise,
register
Hi
configures the indentation of text after headings.
Threshold register
Hc
enables the centering of headings;
a heading level below both of the
Hb
and
Hc
thresholds is centered.
-
Heading typeface and size.
The fonts used for heading numbers and titles at each level are
configured by the
HF
string.
The string
HP
likewise assigns a type size to each heading level.
The vertical spacing used by headings may be controlled by
the use-definable macros
HX
and/or
HZ.
-
Heading number format.
Registers named
H1
through
H14
store counters for each heading level.
Their values are printed using Arabic numerals by default;
see
HM.
The heading levels are catenated with dots for formatting;
to typeset only the deepest,
set the
Ht
register.
Heading numbers are not suffixed with a trailing dot except when only
the first level is output;
to omit a dot in this case as well,
clear the
H1dot
register.
-
Customizing heading behavior.
mm
calls
hook
macros to enable further customization of headings.
(DWB
mm
called these [lq]exits[rq].)
They can be used to change the heading's
mark
(the numbered portion before any heading title),
its vertical spacing,
and its vertical space requirements
(for instance,
to require a minimum quantity of subsequent output lines).
Define hook macros in expectation of the following parameters.
The argument
declare-level
is the
level
argument to
H,
or~0
for unnumbered headings (see
HU).
actua-level
is the same as
declare-level
for numbered headings,
and the value of
register~Hu
for unnumbered headings.
title
is the corresponding argument to
H
or
HU.
-
- HX~declare-level actua-level title
-
mm
calls
HX
before setting the heading.
Your definition may alter
}0,
}2,
and
;3.
-
- }0~(string)
-
contains the heading mark plus two spaces if
declare-level
is no-zero,
and otherwise is empty.
- ;0~(register)
-
encodes a position for the text after the heading.
0~means that the heading is to be run in,
1~means that a break is to occur before the text,
and 2~means that vertical space is to separate heading and text.
- }2~(string)
-
is the suffix that separates a ru-in heading from the text.
It contains two spaces if register
;0
is~0,
and otherwise is empty.
- ;3~(register)
-
contains the vertical space required for the heading to be typeset.
If that amount is not available,
the page is broken prior to the heading.
The default is
2v.
- HY~declare-level actua-level title
-
mm
calls
HY
after determing the heading typeface and size.
It could be used to change indentation.
- HZ~declare-level actua-level title
-
mm
calls
HZ
after formatting the heading,
just before
H
or
HU
returns.
It could be used to change the page header to include a section heading.
- HC [hyphenatio-character]
-
Set hyphenation character.
Default value is [lq][rs]%[rq].
Resets to the default if called without argument.
Hyphenation can be turned off by setting register
Hy
to~0 at the beginning of the file.
- HM [arg1 [arg2 [... [arg14]]]]
-
Set the heading mark style.
Each argument assigns the specified register format
(see above)
to the corresponding heading level.
The default
is~1
for all levels.
An explicitly empty argument also indicates the default.
- HU~headin-text
-
Set an unnumbered section heading.
Except for a heading number,
it is treated as a numbered heading of the level stored in
register~Hu;
see~H.
- I~
-
[itali-text~[previou-fon-text]]~...
Join
itali-text
in italics with
previou-fon-text
in the previous font,
without space between the arguments.
If no arguments,
switch font to italic style.
- IA~[
-
recipien-name~[title]]
Specify the inside address in a letter.
Input is collected into the inside address until
IE
is called,
and then output.
You can specify multiple recipients with empty
IA/IE
pairs;
only the last address is used.
The arguments give each recipient a name and title.
See
LT.
- IB~
-
[itali-text~[bol-text]]~...
Join
itali-text
in italics with
bol-text
in boldface,
without space between the arguments.
- IE
-
End the inside address begun with
IA.
- IND~argument~
-
...
If the Boolean register
Ref
is true,
write an index entry as a specially prepared
roff
comment to the standard error stream,
with each
argument
separated from its predecessor by a tab character.
The entry's location information is arranged as configured by the most
recent
INITI
call.
- INDP
-
Output the index set up by
INITI
and populated by
IND
calls.
By default,
INDP
calls
SK
and writes a centered caption interpolating the string
Index.
It then disables filling and calls
2C;
afterward,
it restores filling and calls
1C.
-
Define macros to customize this behavior.
INDP
calls
TXIND
before the caption,
TYIND
instead
of writing the caption,
and
TZIND
after formatting the index.
- INITI~locatio-type fil-name~
-
[macro]
Initialize
groff mm's
indexing system.
Argument
locatio-type
selects how the location of each index entry is reported.
fil-name
populates an internal string used later by
INDP.
-
| locatio-type | Entry format
|
| N | page number
|
| H | heading mark
|
| B | page number, tab character, heading mark
|
-
If
macro
is specified,
it is called for each index entry
with the arguments given to
IND.
- INITR~id
-
Initialize the cross reference macros.
Cross references are written to the standard error stream,
which should be redirected into a file named
id.qrf.
handles this and the two formatting passes it requires.
The first pass identifies cross references,
and the second one includes them.
-
See
SETR,
GETPN,
and
GETHN.
- IR~
-
[itali-text~[roma-text]]~...
Join
itali-text
in italics with
roma-text
in roman style,
without space between the arguments.
- ISODATE~[0]
-
Use ISO~8601 format for the date string
DT
used by some cover sheet and memorandum types;
that is,
YYYY-MM-DD.
Must be called before
ND
to be effective.
If given an argument
of~0,
the traditional date format for the
groff
locale is used;
this is also the default.
- LB~tex-indent mar-indent pad type~
-
[mark~[pr-ite-space~[pr-lis-space]]]
Begin list.
The macros
AL,
BL,
BVL,
DL,
ML,
RL,
and
VL
call
LB
in various ways;
they are simpler to use and may be preferred if they suit the desired
purpose.
-
The nesting level of lists is tracked by
mm;
the outermost level is~0.
The text of each list item is indented by
tex-indent;
the default is taken from the
Li
register
(in ens).
Each item's mark is indented by
mar-indent;
the default is
0n.
The mark is normally lef-aligned.
If
pad
is greater than zero,
mar-indent
is overridden such that
pad
ens of space follow the mark.
type
selects one of six possible ways to display the mark.
-
| type | Output for a mark [lq]x[rq]
|
| 1 | x.
|
| 2 | x)
|
| 3 | (x)
|
| 4 | [x]
|
| 5 | <x>
|
| 6 | {x}
|
-
If
type
is~0 and
mark
is unspecified,
the items are set with a hanging indent.
Otherwise,
mark
is interpreted as a string defining the mark.
If
type
is greater than zero,
items are automatically numbered;
mark
is interpreted as a register format.
The default
type
is~0.
-
The last two arguments manage vertical space.
Unless a list's nesting level is greater than the value of register
Ls,
its items are preceded by
pr-ite-space
multiplied by the register
Lsp;
the default
is~1.
LB
precedes the list by
pr-lis-space
multiplied by the register
Lsp;
the default
is~0.
- LC~[
-
lis-level]
Clear list state.
Active lists are terminated as if with
LE,
either all
(the default)
or only those from the current level down to
lis-level
if specified.
H
calls
LC
automatically.
- LE~[1]
-
End list.
The current list is terminated.
An argument
of~1
causes
vertical space in the amount of register
Lsp
to follow the list.
- LI~[
-
mark~[ite-mar-mode]]
Begin a list item.
Input is collected into a list item until the current list is terminated
or
LI
is called again.
By default,
the item's text is preceded by any mark configured by the current list.
If only
mark
is specified,
it replaces the configured mark.
A second argument
prefixes
mark
to the configured mark;
an
ite-mar-mode
value of~1 places an unbreakable space after
mark,
while
a value of~2 does not
(rendering the two adjacent).
Also see register
Limsp.
- LO~option~
-
[value]
Specify letter options;
see
LT.
Standard options are as follows.
See
IA
regarding the inside address and string
DT
regarding the date.
-
| option | Effect
|
| AT |
Attention;
put contents of string
LetAT
and
value
lef-aligned after the inside address.
|
| CN |
Confidential;
put
value,
or contents of string
LetCN,
lef-aligned after the date.
|
| RN |
Reference;
put contents of string
LetRN
and
value
after the confidental notation
(if any)
and the date,
aligned with the latter.
|
| SA |
Salutation;
put
value,
or contents of string
LetSA,
lef-aligned after the inside address
and the confidental notation
(if any).
|
| SJ |
Subject;
put contents of string
LetSJ
and
value
lef-aligned after the inside address
and the attention and salutation notations
(if any).
In letter type [lq]SP[rq],
LetSJ
is ignored and
value
is set in full capitals.
|
- LT~[
-
style]
Format a letter in the designated
style,
defaulting to
BL
(see below).
A letter begins with the writer's address
(WA/WE),
followed by the date
(ND),
the inside address
(IA/IE),
the body of the letter
(P
and other genera-purpose
mm
macros),
the formal closing
(FC),
the signature
(SG),
and notations
(NS/NE).
Any of these may be omitted.
Letter options specified with
LO
add further annotations,
which are extensible;
see section [lq]Internals[rq] below.
-
| style | Description
|
| BL |
Blocked:
the writer's address,
date,
formal closing,
and signature are indented to the center of the line.
Everything else is lef-aligned.
|
| SB |
Sem-blocked:
as
BL,
but the first line of each paragraph is indented by
5m.
|
| FB |
Fully blocked:
everything begins at the left margin.
|
| SP |
Simplified:
as
FB,
but a formal closing is omitted,
and the signature is set in full capitals.
|
- MC~colum-width~
-
[gutte-width]
Begin mult-column layout.
groff mm
creates as many columns of
colum-width
as the line length will permit.
gutte-width
is the interior spacing between columns.
It defaults to
colum-width/15.
1C
returns to singl-column layout.
MC
is a GNU extension.
See
MULB
for an alternative.
- ML~mark [tex-indent~[1]]
-
Start a list with the
mark
argument preceding each list item.
tex-indent
overrides the default indentation of the list items set by register
Li.
If a third argument,
conventionally
1,
is given,
the blank line that normally precedes each list item is suppressed.
Use
LI
to declare list items,
and
LE
to end the list.
- MT~
-
[type~[addressee]]
Select memorandum type.
These correspond to formats used by AT&T Bell Laboratories,
where the
mm
package was initially developed,
affecting the document layout.
Some of these included a cover page with a caption categorizing the
document.
groff mm
uses
type
to construct the file name
/usr/:share/:groff/:1.23.0/:tmac/mm/:type:.MT
and load it with the
mso
request.
Memorandum types 0 to~5 are supported;
any other value of
type
is mapped to type~6.
If
type
is omitted,
0
is implied.
addressee
sets a string analogous to one used by AT&T cover sheet macros that are
not implemented in
groff mm.
-
| type | Description
|
| 0 | normal memorandum; no caption
|
| 1 | captioned [lq]MEMORANDUM FOR FILE[rq]
|
| 2 | captioned [lq]PROGRAMMER'S NOTES[rq]
|
| 3 | captioned [lq]ENGINEER'S NOTES[rq]
|
| 4 | released paper
|
| 5 | external letter
|
-
See
COVER
for a more flexible cover sheet mechanism.
- MOVE -pos [-pos [lin-length]]
-
Move to a position, setting page offset to
-pos.
If
lin-length
is not given, the difference between current and new page offset is
used.
Use
PGFORM
without arguments to return to normal.
- MULB~
-
cw1 space1~[cw2 space2] ...~cwn
Begin alternative mult-column mode.
All column widths must be specified,
as must the amount of space between each column pair.
The arguments' default scaling unit is
n.
MULB
uses a diversion and operates in a separate environment.
- MULN
-
Begin next column in alternative column mode.
- MULE
-
End alternative mult-column mode and emit the columns.
- NCOL
-
Move to the start of the next column
(only when using
2C
or
MC).
Contrast with
MULN.
- ND~[
-
arg]
Set the document's date.
mm
does not interpret
arg;
it can be a revision identifier
(or empty).
- NE
-
End notation begun with
NS;
filling is enabled.
- nP [type]
-
Begin a numbered paragraph at heading level two.
See
P.
- NS~[
-
code~[1]]
Declare notations,
typically for letters or memoranda,
of the type specified by
code.
The text corresponding to
code
is output,
and filling is disabled
until
NE
is called.
Typically,
a list of names or attachments lies within
NS/NE.
If
code
is absent or does not match one of the values listed under the
Letns
string description below,
each line of notations is formatted as
[lq]Copy (line) to[rq].
If a second argument,
conventionally
1,
is given,
code
becomes the entire notation and
NE
is not necessary.
In
groff mm,
you can set up further notations to be recognized by
NS;
see the strings
Letns
and
Letnsdef
below.
- OF~[[dq][aq]
-
left[aq]center[aq]right[aq][dq]]
Define the od-page footer,
which is formatted just above the normal page footer on od-numbered
pages.
See
PF.
OF
defines the string
EOPof.
- OH~[[dq][aq]
-
left[aq]center[aq]right[aq][dq]]
Define the od-page header,
which is formatted just below the normal page header on od-numbered
pages.
See
PH.
OH
defines the string
TPoh.
- OP
-
Make sure that the following text is printed at the top of an
od-numbered page.
Does not output an empty page if currently at the top of an odd page.
- P~[
-
type]
Begin new paragraph.
If
type
is missing or~ 0,
P~sets
the paragraph fully left-aligned.
A
type
of~1
idents the first line by
[rs][Pi]
ens.
Set the register
Pt
to select a default paragraph indentation style.
The register
Ps
controls the vertical spacing between paragraphs.
- PE
-
Picture end;
see
- PF~[[dq][aq]
-
left[aq]center[aq]right[aq][dq]]
Define the page footer.
The footer is formatted at the bottom of each page;
the argument is otherwise as described in
PH.
PF
defines the string
EOPf.
See
EF,
OF,
and
EOP.
- PGFORM [linelength [pagelength [pageoffset [1]]]]
-
Set line length, page length, and/or page offset.
This macro can be used for letterheads and similar.
It is normally the first macro call in a file,
though it is not necessary.
PGFORM
can be used without arguments to reset everything after a
MOVE
call.
A line break is done unless the fourth argument is given.
This can be used to avoid the page number on the first page
while setting new width and length.
(It seems as if this macro sometimes doesn't work too well.
Use the comman-line arguments to change
line length, page length, and page offset instead.)
- PGNH
-
Suppress header on the next page.
This macro must be called before any macros that produce output to
affect the layout of the first page.
- PH~[[dq][aq]
-
left[aq]center[aq]right[aq][dq]]
-
Define the page header,
formatted at the top of each page,
as the argument,
where
left,
center,
and
right
are aligned to the respective locations on the line.
A
[lq]%[rq]
character in
arg
is replaced by the page number.
If the argument is absent,
no page header is set.
The default page header is
-
[dq][aq][aq]- % -[aq][aq][dq]
which centers the page number between hyphens and formats nothing at the
upper left and right.
Header macros call
PX
(if defined)
after formatting the header.
PH
defines the string
TPh.
See
EH,
OH,
and
TP.
- PIC~
-
[-B]~[-C|-I~n|-L|-R]~file~[width~[height]]
Include PostScript document
file.
The optional
-B
argument draws a box around the picture.
The optional
-L,
-C,
-R,
and
-I~n
arguments align the picture or indent it by
n
(assuming a scaling unit of
m).
By default,
the picture is lef-aligned.
Optional
width
and
height
arguments resize the picture.
Use of this macro requires tw-pass processing;
see
INITR
and
- PS
-
Picture start; see
- PY
-
Picture end with flyback.
Ends a
picture,
returning the vertical position to where it was prior to the picture.
This is a GNU extension.
- R~
-
[roma-text~[previou-fon-text]]~...
Join
roma-text
in roman style with
previou-fon-text
in the previous font,
without space between the arguments.
If no arguments,
switch font to roman style.
- RB~
-
[roma-text~[bol-text]]~...
Join
roma-text
in roman style with
bol-text
in boldface,
without space between the arguments.
- RD [prompt [diversion [string]]]
-
Read from standard input to diversion and/or string.
The text is saved in a diversion named
diversion.
Recall the text by writing the name of the diversion after a dot
on an empty line.
A string is also defined if
string
is given.
Diversion
and/or
prompt
can be empty ([dq][dq]).
- RF
-
Reference end.
Ends a reference definition and returns to normal processing.
See
RS.
- RI~
-
[roma-text~[itali-text]]~...
Join
roma-text
in roman style with
itali-text
in italics,
without space between the arguments.
- RL~[
-
tex-indent~[1]]
Begin reference list.
Each item is preceded by an automatically incremented number between
square brackets;
compare
AL.
tex-indent
changes the default indentation.
Use
LI
to declare list items,
and
LE
to end the list.
A second argument,
conventionally
1,
suppresses the blank line that normally precedes each list item.
- RP~
-
[suppres-counte-reset~[pag-ejectio-policy]]
Format a reference page,
listing items accumulated within
RS/RF
pairs.
The reference counter is reset unless the first argument
is~1.
Normally,
page breaks occur before and after the references are output;
the register
Rpe
configures this behavior,
and a second argument overrides its value.
TC
calls
RP
automatically if references have accumulated.
-
References are list items,
and thus are vertically separated
(see
LB).
Setting register
Ls
to~0
suppresses this spacing.
The string
Rp
contains the reference page caption.
- RS~[
-
referenc-string]
Begin an automatically numbered reference definition.
By default,
references are numbered starting at 1;
the number is available in register
:R.
Interpolate the string
Rf
where the reference mark should be and write the reference between
RS/RF
on an input line after the reference mark.
If
referenc-string
is specified,
groff ms
also stores the reference mark in a string of that name,
which can be interpolated as
[rs]*[referenc-string]
subsequently.
- S~[
-
typ-size~[vertica-spacing]]
Set type size and vertical spacing.
Each argument is a
groff
measurement,
using an appropriate scaling unit and an optional
+
or
-
prefix to increment or decrement the current value.
An argument of
P
restores the previous value,
C
indicates the current value,
and
D
requests the default.
An empty or omitted argument is treated as
P.
- SA~
-
[mode]
Set or restore the default enablement of adjustment.
Specify
0
or
1
as
mode
to set a document's default explicitly;
1
is assumed by
mm.
Adjustment can be temporarily suspended with the
na
request.
When the
H
or
HU
macros are used to format a heading,
or when
SA
is called without a
mode
argument,
the default adjustment is restored.
- SETR refname [string]
-
Remember the current heading and page numbers as
refname.
Saves
string
if
string
is defined.
string
is retrieved with
GETST.
See
INITR.
- SG [arg [1]]
-
Signature line.
Prints the authors name(s) after the formal closing.
The argument is appended to the reference data, printed at either the
first or last author.
The reference data is the location, department, and initials specified
with
AU.
It is printed at the first author if the second argument is given,
otherwise at the last.
No reference data is printed if the author(s) is specified through
WA/WE.
See section [lq]Internals[rq] below.
- SK~
-
[n]
Skip
n
pages.
If
n
is~0 or omitted,
the page is broken unless the drawing position is already at the top of
a page.
Otherwise,
n
pages,
blank except for any headers and footers,
are printed.
- SM~text~
-
[post]
SM~pre text post
Format
text
at a smaller type size,
joined with any specified
pre
and
post
at normal size.
- SP [lines]
-
Space vertically.
lines
can have any scaling factor,
like [lq]3i[rq] or [lq]8v[rq].
Several
SP
calls in a line only produces the maximum number of lines, not the sum.
SP
is ignored also until the first text line in a page.
Add
[rs]&
before a call to
SP
to avoid this.
- TAB
-
Reset tab stops to every 5~ens.
- TB~
-
[title~[override~[flag~[refname]]]]
Caption a table.
Arguments are handled analogously to
EC.
The register
Tb
is the table counter.
The string
Litb
precedes the table number and any
title.
Table captions are centered irrespective of the alignment of any
enclosing display.
-
Captioned tables are listed in a table of contents
(see
TC)
if the Boolean register
Lt
is true.
Such a list uses the string
Lt
as a heading.
- TC~
-
[slevel~[spacing~[tlevel~[tab~[h1~[h2~[h3~[h4~[h5]]]]]]]]]
Output table of contents.
This macro is normally the last called in the document.
It flushes any pending displays and,
if any references are pending
(see
RS),
calls
RP.
It then begins a new page with the contents caption,
stored in the string
Licon,
centered at the top.
The entries follow after three vees of space.
Each entry is a
saved section
(number and)
heading title
(see the
Cl
register),
along with its associated page number.
By default,
an entry is indented by an amount corresponding to its heading level
and the maximum heading length encountered at that heading level;
if defined,
the string
Ci
overrides these indentations.
Entries at heading levels up to and including
slevel
are preceded by
spacing
vees of space.
Entries at heading levels up to and including
tlevel
are followed by a leader and a righ-aligned page number.
If the Boolea-valued
tab
argument is true,
the leader is replaced with horizontal motion in the same amount.
For entries above heading level
tlevel,
the page number follows the heading text after a word space.
Each argument
h1...h5
appears in order on its own line,
centered,
above the contents caption.
Page numbering restarts at 1,
in register format [lq]i[rq].
If the
Oc
register is true,
numbering of these pages is suppressed.
-
If
TC
is called with at most four arguments,
it calls the use-defined macro
TX
(if defined)
prior to formatting the contents caption,
and
TY
(if defined)
instead
of formatting the contents caption.
-
Analogous handling of lists of figures,
tables,
equations,
and exhibits is achieved by defining
TXxx
and
TYxx
macros,
where
xx
is [lq]FG[rq],
[lq]TB[rq],
[lq]EC[rq],
or [lq]EX[rq],
respectively.
Similarly,
the strings
Lifg,
Litb,
Liex,
and
Liec
determine captions for their respective lists.
- TE
-
Table end.
See
TS.
- TH
-
End table heading.
It is repeated after page breaks within a table.
See
TS.
The
N
argument supported by DWB
mm
is not implemented by
groff mm.
- TL~[
-
chargin-cas-number~[filin-cas-number]]
Begin document title.
Input is collected into the title until
AF
or
AU
is called,
and output as directed by the cover page.
chargin-cas-number
and
filin-cas-number
are saved for use in memorandum types 0 and 5.
See
MT.
- TM~number
-
~...
Declare technical memorandum number(s) used by
MT.
- TP
-
If defined,
this macro is called in lieu of normal page header layout.
Headers and footers are formatted in a separate environment.
See
EOP.
-
Strings available to TP
|
|
| TPh | argument to PH
|
| TPeh | argument to EH
|
| TPoh | argument to OH
|
- TS [H]
-
Table start.
Argument [lq]H[rq] tells
mm
that the table has a heading.
See
TE,
TH,
and
- VERBON~
-
[format~[typ-size~[font]]]
Begin verbatim display,
where characters have equal width.
format
controls several parameters.
Add up the values of desired features;
the default
is~0.
On typesetting devices,
further arguments configure the
typ-size
in scaled points,
and the face
(font);
the default is
CR
(Courier roman).
-
| Value | Effect
|
| 1 | Disable the formatter's escape character ([rs]).
|
| 2 | Vertically space before the display.
|
| 4 | Vertically space after the display.
|
| 8 |
Number output lines; call formatter's
nm
request with arguments in string
Verbnm.
|
| 16 |
Indent by the amount stored in register
Verbin.
|
- VERBOFF
-
End verbatim display.
- VL~[
-
tex-indent~[mar-indent~[1]]]
Begin variabl-item
(or [lq]tagged[rq])
list.
Each item should supply its own mark,
or tag.
If the mark is wider than
mar-indent,
one space separates it from subsequent text;
contrast
BVL.
tex-indent
sets the indentation of the text,
and
mar-indent
the distance from the current list indentation to the mark.
A third argument suppresses the blank line that normally precedes each
list item.
Use
LI
to declare list items,
and
LE
to end the list.
- VM [-T] [top [bottom]]
-
Vertical margin.
Increase the top and bottom margin by
top
and
bottom,
respectively.
If option
-T
is specified, set those margins to
top
and
bottom.
If no argument is given, reset the margin to zero, or to the default
([lq]7v 5v[rq])
if
-T
is used.
It is highly recommended that macros
TP
and/or
EOP
are defined if using
-T
and setting top and/or bottom margin to less than the default.
This undocumented DWB
mm
macro is exposed by
groff mm
to increase user control of page layout.
- WA~[
-
writer'-name~[title]]
Specify the writer(s) of an
LT
letter.
Input is collected into the writer's address until
WA
is called,
and then output.
You can specify multiple writers with empty
WA/WE
pairs;
only the last address is used.
The arguments give each writer a name and title.
- WC~[
-
format~...]
Control width of footnotes and displays.
-
-
| format | Effect
|
| N |
equivalent to
[lq][rq]
(default)
|
| WF |
set footnotes at full line length,
even in tw-column mode
|
| -WF |
set footnotes using column line length
|
| FF |
apply width of first footnote to encountered to subsequent ones
|
| -FF |
footnote width determined by
WF
and
|
| WD |
set displays at full line length,
even in tw-column mode
|
| -WD |
set displays using column line length
|
- WE
-
End the writer's address begun with
WA.
Strings
Many
mm
strings interpolate predefined,
localizable text.
These are presented in quotation marks.
- App
-
[lq]APPENDIX[rq]
- Apptxt
-
stores the
title
argument to the last
APP
call.
- BU
-
interpolates a bullet
(see
BL).
- Ci
-
is a list of indentation amounts to use for table of contents heading
levels,
overriding their automatic computation.
Each word must be a horizontal measurement
(like
[lq]1i[rq])
and is mapped on-t-one to heading levels 1,
2,
and so on.
- DT
-
The date;
set by the
ND
macro
(defaults to the date the document is formatted).
The format is the conventional one for the
groff
locale,
but see the
ISODATE
macro and
Iso
register.
- EM
-
interpolates an em dash.
- F
-
interpolates an automatically numbered footnote marker;
the number is used by the next
FS
call without an argument.
In
troff
mode,
the marker is superscripted;
in
nroff
mode,
it is surrounded by square brackets.
- H1txt
-
Updated by
.H
and
.HU
to the current heading text.
Also updated in table of contents & friends.
- HF
-
assigns font identifiers,
separated by spaces,
to heading levels in on-t-one correspondence.
Each identifier may be a font mounting position,
font name,
or style name.
Omitted values are assumed to be~1.
The default is
[lq]2 2 2 2 2 2 2 2 2 2 2 2 2 2[rq],
which places all headings in italics.
DWB
mm's
default was
[lq]3 3 2 2 2 2 2[rq].
- HP
-
assigns type sizes,
separated by spaces,
to heading levels in on-t-one correspondence.
Each size is interpreted in scaled points;
zero values are translated to
10.
Omitted values are assumed to be~0
(and are translated accordingly).
The default is
[lq]0 0 0 0 0 0 0 0 0 0 0 0 0 0[rq].
- Index
-
[lq]INDEX[rq]
- Le
-
[lq]LIST OF EQUATIONS[rq]
- Letfc
-
[lq]Yours very truly,[rq]
(see
FC)
- Letapp
-
[lq]APPROVED:[rq]
(see
AV)
- LetAT
-
[lq]ATTENTION:[rq]
(see
LO)
- LetCN
-
[lq]CONFIDENTIAL[rq]
(see
LO)
- Letdate
-
[lq]Date[rq]
(see
AV)
- Letns
-
is a group of strings structuring the notations produced by
NS.
If the
code
argument to
NS
has no corresponding string,
the notation is included between parentheses,
prefixed with
Letns!copy,
and suffixed with
Letns!to.
Observe the spaces after [lq]Copy[rq] and before [lq]to[rq].
-
| NS code | String | Contents
|
| 0 | Letns!0 | Copy to
|
| 1 | Letns!1 | Copy (with att.) to
|
| 2 | Letns!2 | Copy (without att.) to
|
| 3 | Letns!3 | Att.
|
| 4 | Letns!4 | Atts.
|
| 5 | Letns!5 | Enc.
|
| 6 | Letns!6 | Encs.
|
| 7 | Letns!7 | Under separate cover
|
| 8 | Letns!8 | Letter to
|
| 9 | Letns!9 | Memorandum to
|
| 10 | Letns!10 | Copy (with atts.) to
|
| 11 | Letns!11 | Copy (without atts.) to
|
| 12 | Letns!12 | Abstract Only to
|
| 13 | Letns!13 | Complete Memorandum to
|
| 14 | Letns!14 | CC
|
| [em] | Letns!copy | Copy (with trailing space)
|
| [em] | Letns!to | to (note leading space)
|
- Letnsdef
-
Select the notation format used by
NS
when it is given no argument.
The default is
[lq]0[rq].
- LetRN
-
[lq]In reference to:[rq]
(see
LO)
- LetSA
-
[lq]To Whom It May Concern:[rq]
(see
LO)
- LetSJ
-
[lq]SUBJECT:[rq]
(see
LO)
- Lf
-
[lq]LIST OF FIGURES[rq]
- Licon
-
[lq]CONTENTS[rq]
- Liec
-
[lq]Equation[rq]
- Liex
-
[lq]Exhibit[rq]
- Lifg
-
[lq]Figure[rq]
- Litb
-
[lq]TABLE[rq]
- Lt
-
[lq]LIST OF TABLES[rq]
- Lx
-
[lq]LIST OF EXHIBITS[rq]
- MO1...MO12
-
[lq]January[rq] through [lq]December[rq]
- Qrf
-
[lq]See chapter [rs][rs]*[Qrfh],
page [rs][rs]n[Qrfp].[rq]
- Rf
-
interpolates an automatically numbered reference mark;
the number is used by the next
RS
call.
In
troff
mode,
the marker is superscripted;
in
nroff
mode,
it is surrounded by square brackets.
- Rp
-
[lq]REFERENCES[rq]
- Sm
-
interpolates
the service mark sign.
- Tcst
-
interpolates an indicator of the
TC
macro's processing status.
If
TC
is not operating,
it is empty.
Use-defined
TP
or
EOP
macros might condition page headers or footers on its contents.
-
| Value | Meaning
|
| co | Table of contents
|
| fg | List of figures
|
| tb | List of tables
|
| ec | List of equations
|
| ex | List of exhibits
|
| ap | Appendix
|
- Tm
-
interpolates
the trade mark sign.
- Verbnm
-
supplies argument(s) to the
nm
request employed by the
VERBON
macro.
The default is~[lq]1[rq].
Registers
Default register values,
where meaningful,
are shown in parentheses.
Many are also marked as Boolea-valued,
meaning that they are considered [lq]true[rq]
(on,
enabled)
when they have a positive value,
and [lq]false[rq]
(off,
disabled)
otherwise.
- .mgm
-
indicates that
groff mm
is in use
(Boolea-valued;
1).
- :p
-
is an aut-incrementing footnote counter;
see
FS.
- :R
-
is an aut-incrementing reference counter;
see
RS.
- Aph
-
formats an appendix heading
(and title,
if supplied);
see
APP
(Boolea-valued;
1).
- Au
-
includes supplemental author information
(the third and subsequent arguments to
AU)
in memorandum [lq]from[rq] information;
see
COVER
and
MT
(Boolea-valued;
1).
- Cl
-
sets the threshold for inclusion of headings in a table of contents.
Headings at levels above this value are excluded;
see
H
and
TC
(2).
The
Cl
register controls whether a heading is
saved
for output in the table of contents at the time
H
or
HU
is called;
if you change
Cl's
value immediately prior to calling
TC,
you are unlikely to get the result you want.
- Cp
-
suppresses page breaks before lists of captioned
equations,
exhibits,
figures,
and tables,
and before an index;
see
EC,
EX,
FG,
TB,
and
INDP
(Boolea-valued;
0).
- D
-
produces debugging information for the
mm
package on the standard error stream.
A value of~0 outputs nothing;
1~reports formatting progress.
Higher values communicate internal state information of increasing
verbosity
(0).
- De
-
causes a page break after a floating display is output;
see
DF
(Boolea-valued;
0).
- Df
-
configures the behavior of
DF.
The following values are recognized;
4 and 5 do not override the
De
register
(5).
-
| Value | Effect
|
| 0 |
Flush pending displays
at the end of each section
when sectio-page numbering is active,
otherwise at the end of the document.
|
| 1 |
Flush a pending display
on the current page or column
if there is enough space,
otherwise at the end of the document.
|
| 2 |
Flush one pending display
at the top of each page or column.
|
| 3 |
Flush a pending display
on the current page or column
if there is enough space,
otherwise at the top of the next.
|
| 4 |
Flush as many pending displays
as possible in a new page or column.
|
| 5 |
Fill columns or pages with flushed displays
until none remain.
|
- Ds
-
puts vertical space in the amount of register
Dsp
(if defined) or
Lsp
before and after each static display;
see
DS
(Boolea-valued;
1).
- Dsp
-
configures the amount of vertical space placed
before and after static displays;
see
DS
and register
Ds
(undefined).
- Ec
-
is an aut-incrementing equation counter;
see
EC.
- Ej
-
sets the threshold for page breaks (ejection) prior to the format of
headings.
Headings at levels above this value are set on the same page and column
if possible;
see
H
(0).
- Eq
-
aligns an equation label to the left of a display instead of the right
(Boolea-valued;
0).
- Ex
-
is an aut-incrementing exhibit counter;
see
EX.
- Fg
-
is an aut-incrementing figure counter;
see
FG.
- Fs
-
is multiplied by register
Lsp
to vertically separate footnotes;
see
FS
(1).
- H1...H14
-
are aut-incrementing counters corresponding to each heading level;
see
H.
- H1dot
-
appends a period to the number of a level one heading;
see
H
(Boolea-valued;
1).
- H1h
-
is a copy of
A copy of register
register~H1,
but it is incremented just before a page break.
This can be useful in use-defined macros;
see
H
and
HX.
- Hb
-
sets the threshold for breaking the line after formatting a heading.
Text after headings at levels above this value are set on the same
output line if possible;
see
H
(2).
- Hc
-
sets the threshold for centering a heading.
Headings at levels above this value use the prevailing alignment
(that is,
they are not centered);
see
H
(0).
- Hi
-
configures the indentation of text after headings.
It does not affect [lq]ru-in[rq] headings.
The following values are recognized;
see
H
and
P
(1).
-
| Value | Effect
|
| 0 | no indentation
|
| 1 | indent per the paragraph type
|
| 2 | indent to align with heading title
|
- Hps
-
sets the heading level threshold for application of preceding vertical
space;
see
H.
Headings at levels above the value in register
Hps
use the amount of space in register
Hps1;
otherwise that in
Hps2.
The value of
Hps
should be strictly greater than that of
Ej
(1).
- Hps1
-
configures the amount of vertical space preceding a heading above the
Hps
threshold;
see
H
(troff
devices:
0.5v;
nroff
devices:
1v).
- Hps2
-
configures the amount of vertical space preceding a heading at or below
the
Hps
threshold;
see
H
(troff
devices:
1v;
nroff
devices:
2v).
- Hs
-
sets the heading level threshold for application of succeeding vertical
space.
If the heading level is greater than
Hs,
the heading is followed by vertical space in the amount of
register~Hss;
see
H
(2).
- Hss
-
is multiplied by register
Lsp
to produce vertical space after headings above the
threshold in
register~Hs;
see
H
(1).
- Ht
-
suppresses output of heading level counters above the lowest when the
heading is formatted;
see
H
(Boolea-valued;
0).
- Hu
-
sets the heading level used by unnumbered headings;
see
HU
(2).
- Hy
-
enables automatic hyphenation of words
(Boolea-valued;
0).
- Iso
-
configures the use of ISO~8601 date format
if specified
(with any value)
on the command line;
see
ISODATE.
The default is determined by localization files.
- L
-
defines the page length for the document,
and must be set from the command line.
A scaling unit should be appended.
The default is that of the selected
groff
output device.
- Le
-
Lf
Lt
Lx
configure the report of lists of equation,
figure,
table,
and exhibit captions,
respectively,
after a table of contents;
see
TC
(Boolea-valued;
Le:~0;
Lf,
Lt,
Lx:~1).
- Letwam
-
sets the maximum number of input lines permitted in a writer's address;
see
WA
and
WE
(14).
- Li
-
configures the amount of indentation in ens applied to list items;
see
LI
(6).
- Limsp
-
inserts a space between the prefix and the mark
in automatically numbered lists;
see
AL
(Boolea-valued;
1).
- Ls
-
sets a threshold for placement of vertical space before list items.
If the list nesting level is greater than this value,
no such spacing occurs;
see
LI
(99).
- Lsp
-
configures the base amount of vertical space used for separation
in the document.
mm
applies this spacing to many contexts,
sometimes with multipliers;
see
DS,
FS,
H,
LI,
and
P
(troff
devices:
0.5v;
nroff
devices:
1v).
- N
-
configures the header and footer placements used by
PH.
The default footer is empty.
If [lq]sectio-page[rq] numbering is selected,
the default header becomes empty
and the default footer becomes
[lq]x-y[rq],
where
x~is
is the section number
(the number of the current firs-level heading)
and~y
the page number within the section.
The following values are recognized;
for finer control,
see
PH,
PF,
EH,
EF,
OH,
and
OF,
and registers
Sectf
and
Sectp.
Value 5 is a GNU extension
(0).
-
| Value | Effect
|
| 0 | Set header on all pages.
|
| 1 | Move header to footer on page 1.
|
| 2 | Omit header on page 1.
|
| 3 | Use [lq]sectio-page[rq] numbering style on all pages.
|
| 4 | Omit header on all pages.
|
| 5 |
Use [lq]sectio-page[rq] and [lq]sectio-figure[rq] numbering style on all pages.
|
- Np
-
causes paragraphs after firs-level headings (only) to be numbered
in the format
s.p,
where
s~is
is the section number
(the number of the current firs-level heading)
and
p~is
the paragraph number,
starting at 1;
see
H
and
P
(Boolea-valued;
0).
- O
-
defines the page offset of the document,
and must be set from the command line.
A scaling unit should be appended.
The default
is~.75i
on terminal devices.
On typesetters,
it is
.963i
or set to
1i
by the
papersize.tmac
package;
see
- Oc
-
suppresses the appearance of page numbers in the table of contents;
see
TC
(Boolea-valued;
0).
- Of
-
selects a separator format within equation,
exhibit,
figure,
and table captions;
see
EC,
EX,
FG,
and
TB.
The following values are recognized;
the spaces shown are unpaddable
(0).
-
| Value | Effect
|
| 0 | [dq]. [dq]
|
| 1 | [dq] [em] [dq]
|
- P
-
interpolates the current page number;
it is the same as
register~%
except when
[lq]sectio-page[rq] numbering is enabled.
- Pi
-
configures the amount of indentation in ens applied to the first line of
a paragraph;
see
P
(5).
- Pgps
-
causes the type size and vertical spacing set by
S
to apply to headers and footers,
overriding the
HP
string.
If not set,
S
calls affect headers and footers only when followed by
PH,
PF,
OH,
EH,
OF,
or
OE
calls
(Boolea-valued;
1).
- Ps
-
is multiplied by register
Lsp
to vertically separate paragraphs;
see
P
(1).
- Pt
-
determines when a firs-line indentation is applied to a paragraph;
see
P
(0).
-
| Value | Effect
|
| 0 | never
|
| 1 | always
|
| 2 |
always,
except immediately after
H,
DE,
or
LE
|
- Ref
-
is used internally to control
tw-pass approach to index and reference management;
see
INITI
and
RS
(Boolea-valued;
0).
- Rpe
-
configures the default page ejection policy for reference pages;
see
RP
(0).
-
| Value | Effect
|
| 0 | Break the page before and after the list of references.
|
| 1 | Suppress page break after the list.
|
| 2 | Suppress page break before the list.
|
| 3 | Suppress page breaks before and after the list.
|
- S
-
defines the type size for the document,
and must be set from the command line.
A scaling unit should be appended;
p
is typical
(10p).
- Sectf
-
selects the [lq]sectio-figure[rq] numbering style.
Its default
is~0
unless
register~N
is set
to~5
at the command line
(Boolea-valued).
- Sectp
-
selects the [lq]sectio-page[rq] numbering style.
Its default
is~0
unless
register~N
is set
to~3
or~5
at the command line
(Boolea-valued).
- Si
-
configures the amount of display indentation in ens;
see
DS
(5).
- Tb
-
is an aut-incrementing table counter;
see
TB.
- V
-
defines the vertical spacing for the document,
and must be set from the command line.
A scaling unit should be appended;
p
is typical.
The default vertical spacing is 120% of the type size.
- Verbin
-
configures the amount of indentation for verbatim displays
when indentation is selected;
see
VERBON
(5n).
- W
-
defines the [lq]width[rq]
of the document
(that is,
the length of an output line with no indentation);
it must be set from the command line.
A scaling unit should be appended.
The default
is~6i
or assigned by the
papersize.tmac
package;
see
Internals
The
LT
letter macros call further macros depending on the letter type,
with which they are suffixed.
It is therefore possible to define additional letter types,
either in the territor-specific macro file,
or as local additions.
LT
sets the registers
Pt
and
Pi
to 0 and~5, respectively.
The following macros must be defined to support a new letter type.
- let@init_type
-
LT
calls this macro to initialize any registers and other data needed by
the letter type.
- let@head_type
-
formats the letterhead;
it is called instead of the usual page header macro.
Its definition should remove the alias
let@header
unless the letterhead is desired on subsequent pages.
- let@sg_type~
-
name title n i-final~[S-arg~...]
SG
calls this macro only for letters;
MT
memoranda have their own signature processing.
name
and
title
are specified through
WA/WE.
n~is
the index of the
nth
writer,
and
i-final
is true for the last writer to be listed.
Further
SG
arguments are appended to the signature line.
- let@fc_type closing
-
This macro is called by
FC,
and has the formal closing as the argument.
LO
implements letter options.
It requires that a string named
Lettype
be defined,
where
type
is the letter type.
LO
then assigns its second argument
(value)
to the string
let*lo-type.
Files
- /usr/:share/:groff/:1.23.0/:tmac/m.tmac
-
is the
groff
implementation of the memorandum macros.
- /usr/:share/:groff/:1.23.0/:tmac/mm.tmac
-
is wrapper to load
m.tmac.
- /usr/:share/:groff/:1.23.0/:tmac/refer-mm.tmac
-
implements
support for
mm.
- /usr/:share/:groff/:1.23.0/:tmac/mm/ms.cov
-
implements an
ms-like
cover sheet.
- /usr/:share/:groff/:1.23.0/:tmac/mm/0.MT
-
implements memorandum types 0[en]3 and 6.
- /usr/:share/:groff/:1.23.0/:tmac/mm/4.MT
-
implements memorandum type 4.
- /usr/:share/:groff/:1.23.0/:tmac/mm/5.MT
-
implements memorandum type 5.
- /usr/:share/:groff/:1.23.0/:tmac/mm/locale
-
performs any (further) desired necessary localization;
empty by default.
Authors
The GNU version of the
mm
macro package was written by
J[:o]rgen H[:a]gg
of Lund, Sweden.
See also
MM - A Macro Package for Generating Documents
the DWB~3.3
mm
manual,
introduces the package but does not document GNU extensions.
Groff: The GNU Implementation of troff,
by Trent A. Fisher and Werner Lemberg,
is the primary
groff
manual.
You can browse it interactively with [lq]info groff[rq].
Index
- Name
-
- Synopsis
-
- Description
-
- Document styles
-
- Localization
-
- Registers and strings
-
- Register format
-
- Fonts
-
- Macros
-
- Strings
-
- Registers
-
- Internals
-
- Files
-
- Authors
-
- See also
-
|
|