81c4d5981a
Add Caldera license. Approved by: David Taylor <davidt@caldera.com>
401 lines
16 KiB
Plaintext
401 lines
16 KiB
Plaintext
.\" Copyright (C) Caldera International Inc. 2001-2002. All rights reserved.
|
|
.\"
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
.\" modification, are permitted provided that the following conditions are
|
|
.\" met:
|
|
.\"
|
|
.\" Redistributions of source code and documentation must retain the above
|
|
.\" copyright notice, this list of conditions and the following
|
|
.\" disclaimer.
|
|
.\"
|
|
.\" Redistributions in binary form must reproduce the above copyright
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
.\"
|
|
.\" All advertising materials mentioning features or use of this software
|
|
.\" must display the following acknowledgement:
|
|
.\"
|
|
.\" This product includes software developed or owned by Caldera
|
|
.\" International, Inc. Neither the name of Caldera International, Inc.
|
|
.\" nor the names of other contributors may be used to endorse or promote
|
|
.\" products derived from this software without specific prior written
|
|
.\" permission.
|
|
.\"
|
|
.\" USE OF THE SOFTWARE PROVIDED FOR UNDER THIS LICENSE BY CALDERA
|
|
.\" INTERNATIONAL, INC. AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR
|
|
.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
.\" WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
.\" DISCLAIMED. IN NO EVENT SHALL CALDERA INTERNATIONAL, INC. BE LIABLE
|
|
.\" FOR ANY DIRECT, INDIRECT INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
.\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
.\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
|
|
.\" BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
|
.\" WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
|
|
.\" OR OTHERWISE) RISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
|
|
.\" IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
.\"
|
|
.\" @(#)m2 8.1 (Berkeley) 8/14/93
|
|
.\"
|
|
.\" $FreeBSD$
|
|
.tr |
|
|
.rm mx
|
|
.br
|
|
.mh
|
|
Line Length and Indenting
|
|
.pg
|
|
The maximum line length for fill mode may be set with \fBll\fR.
|
|
The indent may be set with \fBin\fR;
|
|
an indent applicable to \fIonly\fR the \fInext\fR output line may be set with \fBti\fR.
|
|
The line length includes indent space but \fInot\fR
|
|
page offset space.
|
|
The line-length minus the indent is the basis for centering with \fBce\fR.
|
|
The effect of \fBll\fR, \fBin\fR, or \fBti\fR
|
|
is delayed, if a partially collected line exists,
|
|
until after that line is output.
|
|
In fill mode the length of text on an output line is less than or equal to
|
|
the line length minus the indent.
|
|
The current line length and indent are available in registers \fB.l\fR and \fB.i\fR respectively.
|
|
The length of \fIthree-part titles\fR produced by \fBtl\fR
|
|
(see \(sc14) is \fIindependently\fR set by \fBlt\fR.
|
|
.h1
|
|
.bt
|
|
\fB&ll\fI|\(+-N\fR 6.5\|in previous E,\fBm\fR Line length is set to \(+-\fIN\fR.
|
|
In \*(TR the maximum (line-length)+(page-offset) is about 7.54 inches.
|
|
.bt
|
|
\fB&in\fI|\(+-N\fR \fIN\(eq\^\fR0 previous B,E,\fBm\fR Indent is set to \fI\(+-N\fR.
|
|
The indent is prepended to each output line.
|
|
.bt
|
|
\fB&ti\fI|\(+-N\fR - ignored B,E,\fBm\fR Temporary indent.
|
|
The \fInext\fR output text line will be indented a distance \fI\(+-N\fR
|
|
with respect to the current indent.
|
|
The resulting total indent may not be negative.
|
|
The current indent is not changed.
|
|
.mh
|
|
Macros, Strings, Diversion, and Position Traps
|
|
.sc
|
|
Macros and strings.
|
|
A \fImacro\fR is a named set of arbitrary \fIlines\fR that may be invoked by name or
|
|
with a \fItrap\fR.
|
|
A \fIstring\fR is a named string of \fIcharacters\fR,
|
|
\fInot\fR including a newline character,
|
|
that may be interpolated by name at any point.
|
|
Request, macro, and string names share the \fIsame\fR name list.
|
|
Macro and string names
|
|
may be one or two characters long and may usurp previously defined
|
|
request, macro, or string names.
|
|
Any of these entities may be renamed with \fBrn\fR
|
|
or removed with \fBrm\fR.
|
|
Macros are created by \fBde\fR and \fBdi\fR, and appended to by \fBam\fR and \fBda\fR;
|
|
\fBdi\fR and \fBda\fR cause normal output to be stored in a macro.
|
|
Strings are created by \fBds\fR and appended to by \fBas\fR.
|
|
A macro is invoked in the same way as a request;
|
|
a control line beginning \fB.\fIxx\fR will interpolate the contents of macro \fIxx\fR.
|
|
The remainder of the line may contain up to nine \fIarguments\fR.
|
|
The strings \fIx\fR and \fIxx\fR are interpolated at any desired point with
|
|
\fB\e\(**\fIx\fR and \fB\e\(**(\fIxx\fR respectively.
|
|
String references and macro invocations may be nested.
|
|
.sc
|
|
Copy mode input interpretation.
|
|
During the definition and extension
|
|
of strings and macros (not by diversion)
|
|
the input is read in \fIcopy mode\fR.
|
|
The input is copied without interpretation
|
|
\fIexcept\fR that:
|
|
.x1
|
|
.ds + \v'-.1m'\s-4\(bu\s+4\v'+.1m'
|
|
\(bu The contents of number registers indicated by \fB\en\fR are interpolated.
|
|
\(bu Strings indicated by \fB\e\(**\fR are interpolated.
|
|
\(bu Arguments indicated by \fB\e$\fR are interpolated.
|
|
\(bu Concealed newlines indicated by \fB\e\fR(newline) are eliminated.
|
|
\(bu Comments indicated by \fB\e"\fR are eliminated.
|
|
\(bu \fB\et\fR and \fB\ea\fR are interpreted as \s-1ASCII\s+1 horizontal tab and \s-1SOH\s+1 respectively (\(sc9).
|
|
\(bu \fB\e\e\fR is interpreted as \fB\e\fR.
|
|
\(bu \fB\e.\fR is interpreted as "\fB.\fR".
|
|
.x2
|
|
These interpretations can be suppressed by
|
|
prepending
|
|
a \fB\e\fR.
|
|
For example, since \fB\e\e\fR maps into a \fB\e\fR, \fB\e\en\fR will copy as \fB\en\fR which
|
|
will be interpreted as a number register indicator when the
|
|
macro or string is reread.
|
|
.sc
|
|
Arguments.
|
|
When a macro is invoked by name, the remainder of the line is
|
|
taken to contain up to nine arguments.
|
|
The argument separator is the space character, and arguments
|
|
may be surrounded by double-quotes to permit imbedded space characters.
|
|
Pairs of double-quotes may be imbedded in double-quoted arguments to
|
|
represent a single double-quote.
|
|
If the desired arguments won't fit on a line,
|
|
a concealed newline may be used to continue on the next line.
|
|
.pg
|
|
When a macro is invoked the \fIinput level\fR is \fIpushed down\fR and
|
|
any arguments available at the previous level become unavailable
|
|
until the macro is completely read and the previous level is restored.
|
|
A macro's own arguments can be interpolated at \fIany\fR point
|
|
within the macro with \fB\e$\fIN\fR, which interpolates the \fIN\fR\^th
|
|
argument
|
|
(1\(<=\fIN\fR\^\(<=9).
|
|
If an invoked argument doesn't exist,
|
|
a null string results.
|
|
For example, the macro \fIxx\fR may be defined by
|
|
.x1
|
|
.ft B
|
|
.ta .75i
|
|
&de xx \e"begin definition
|
|
Today is \e\e$1 the \e\e$2.
|
|
&. \e"end definition
|
|
.ft R
|
|
.x2
|
|
and called by
|
|
.x1
|
|
.ft B
|
|
&xx Monday 14th
|
|
.ft R
|
|
.x2
|
|
to produce the text
|
|
.x1
|
|
.ft B
|
|
Today is Monday the 14th.
|
|
.ft R
|
|
.x2
|
|
Note that the \fB\e$\fR
|
|
was concealed in the definition with a prepended \fB\e\fR.
|
|
The number of currently available
|
|
arguments is in the \fB.$\fR register.
|
|
.pg
|
|
No arguments are available at the top (non-macro) level
|
|
in this implementation.
|
|
Because string referencing is implemented
|
|
as a input-level push down,
|
|
no arguments are available from \fIwithin\fR a string.
|
|
No arguments are available within a trap-invoked macro.
|
|
.pg
|
|
Arguments are copied in \fIcopy mode\fR onto a stack
|
|
where they are available for reference.
|
|
The mechanism does not allow an argument to contain
|
|
a direct reference to a \fIlong\fR string
|
|
(interpolated at copy time) and it is advisable to
|
|
conceal string references (with an extra \fB\e\fR\|)
|
|
to delay interpolation until argument reference time.
|
|
.sc
|
|
Diversions.
|
|
Processed output may be diverted into a macro for purposes
|
|
such as footnote processing (see Tutorial \(scT5)
|
|
or determining the horizontal and vertical size of some text for
|
|
conditional changing of pages or columns.
|
|
A single diversion trap may be set at a specified vertical position.
|
|
The number registers \fBdn\fR and \fBdl\fR respectively contain the
|
|
vertical and horizontal size of the most
|
|
recently ended diversion.
|
|
Processed text that is diverted into a macro
|
|
retains the vertical size of each of its lines when reread
|
|
in \fInofill\fR mode
|
|
regardless of the current \fIV\fR.
|
|
Constant-spaced (\fBcs\fR) or emboldened (\fBbd\fR) text that is diverted
|
|
can be reread correctly only if these modes are again or still in effect
|
|
at reread time.
|
|
One way to do this is to imbed in the diversion the appropriate
|
|
\fBcs\fR or \fBbd\fR requests with the \fItransparent\fR
|
|
mechanism described in \(sc10.6.
|
|
.pg
|
|
Diversions may be nested
|
|
and certain parameters and registers
|
|
are associated
|
|
with the current diversion level
|
|
(the top non-diversion level may be thought of as the
|
|
0th diversion level).
|
|
These are the diversion trap and associated macro,
|
|
no-space mode,
|
|
the internally-saved marked place (see \fBmk\fR and \fBrt\fR),
|
|
the current vertical place (\fB.d\fR register),
|
|
the current high-water text base-line (\fB.h\fR register),
|
|
and the current diversion name (\fB.z\fR register).
|
|
.sc
|
|
Traps.
|
|
Three types of trap mechanisms are available\(empage traps, a diversion trap, and
|
|
an input-line-count trap.
|
|
Macro-invocation traps may be planted using \fBwh\fR at any page position including the top.
|
|
This trap position may be changed using \fBch\fR.
|
|
Trap positions at or below the bottom of the page
|
|
have no effect unless or until
|
|
moved to within the page or rendered effective by an increase in page length.
|
|
Two traps may be planted at the \fIsame\fR position only by first planting them at different
|
|
positions and then moving one of the traps;
|
|
the first planted trap will conceal the second unless and until the first one is moved
|
|
(see Tutorial Examples \(scT5).
|
|
If the first one is moved back, it again conceals the second trap.
|
|
The macro associated with a page trap is automatically
|
|
invoked when a line of text is output whose vertical size \fIreaches\fR
|
|
or \fIsweeps past\fR the trap position.
|
|
Reaching the bottom of a page springs the top-of-page trap, if any,
|
|
provided there is a next page.
|
|
The distance to the next trap position is available in the \fB.t\fR register;
|
|
if there are no traps between the current position and the bottom of the page,
|
|
the distance returned is the distance to the page bottom.
|
|
.pg
|
|
A macro-invocation trap effective in the current diversion may be planted using \fBdt\fR.
|
|
The \fB.t\fR register works in a diversion; if there is no subsequent trap a \fIlarge\fR
|
|
distance is returned.
|
|
For a description of input-line-count traps, see the \fBit\fR request below.
|
|
.h1
|
|
.bt
|
|
\fB&de\fI|xx|yy\fR - \fI.yy=\fB..\fR - Define or redefine the macro \fIxx\fR.
|
|
The contents of the macro begin on the next input line.
|
|
Input lines are copied in \fIcopy mode\fR until the definition is terminated by a
|
|
line beginning with \fB.\fIyy\fR,
|
|
whereupon the macro \fIyy\fR is called.
|
|
In the absence of \fIyy\fR, the definition
|
|
is terminated by a
|
|
line beginning with "\fB..\fR".
|
|
A macro may contain \fBde\fR requests
|
|
provided the terminating macros differ
|
|
or the contained definition terminator is concealed.
|
|
\&"\fB..\fR" can be concealed as
|
|
\fB\e\e..\fR which will copy as \fB\e..\fR and be reread as "\fB..\fR".
|
|
.bt
|
|
\fB&am\fI|xx|yy\fR - \fI.yy=\fB..\fR - Append to macro (append version of \fBde\fR).
|
|
.bt
|
|
\fB&ds\fI|xx|string\fR - ignored - Define a string
|
|
\fIxx\fR containing \fIstring\fR.
|
|
Any initial double-quote in \fIstring\fR is stripped off to permit
|
|
initial blanks.
|
|
.bt
|
|
\fB&as\fI|xx|string\fR - ignored - Append
|
|
\fIstring\fR to string \fIxx\fR
|
|
(append version of \fBds\fR).
|
|
.bt
|
|
\fB&rm\fI|xx\fR - ignored - Remove
|
|
request, macro, or string.
|
|
The name \fIxx\fR is removed from the name list and
|
|
any related storage space is freed.
|
|
Subsequent references will have no effect.
|
|
.bt
|
|
\fB&rn\fI|xx|yy\fR - ignored - Rename request, macro, or string
|
|
\fIxx\fR to \fIyy\fR.
|
|
If \fIyy\fR exists, it is first removed.
|
|
.bt
|
|
\fB&di|\fIxx\fR - end D Divert output to macro \fIxx\fR.
|
|
Normal text processing occurs during diversion
|
|
except that page offsetting is not done.
|
|
The diversion ends when the request \fBdi\fR or \fBda\fR is encountered without an argument;
|
|
extraneous
|
|
requests of this type should not appear when nested diversions are being used.
|
|
.bt
|
|
\fB&da|\fIxx\fR - end D Divert, appending to \fIxx\fR
|
|
(append version of \fBdi\fR).
|
|
.bt
|
|
\fB&wh\fI|N|xx\fR - - \fBv\fR Install
|
|
a trap to invoke \fIxx\fR at page position \fIN;\fR
|
|
a \fInegative N\fR will be interpreted with respect to the
|
|
page \fIbottom\fR.
|
|
Any macro previously planted at \fIN\fR is replaced by \fIxx\fR.
|
|
A zero \fIN\fR refers to the \fItop\fR of a page.
|
|
In the absence of \fIxx\fR, the first found trap at \fIN\fR, if any, is removed.
|
|
.bt
|
|
\fB&ch\fI|xx|N\fR - - \fBv\fR Change
|
|
the trap position for macro \fIxx\fR to be \fIN\fR.
|
|
In the absence of \fIN\fR, the trap, if any, is removed.
|
|
.bt
|
|
\fB&dt\fI|N|xx\fR - off D,\fBv\fR Install a diversion trap
|
|
at position \fIN\fR in the \fIcurrent\fR diversion to invoke
|
|
macro \fIxx\fR.
|
|
Another \fBdt\fR will redefine the diversion trap.
|
|
If no arguments are given, the diversion trap is removed.
|
|
.bt
|
|
\fB&it\fI|N|xx\fR - off E Set an input-line-count trap
|
|
to invoke the macro \fIxx\fR after \fIN\fR lines of \fItext\fR input
|
|
have been read
|
|
(control or request lines don't count).
|
|
The text may be in-line text or
|
|
text interpolated by inline or trap-invoked macros.
|
|
.bt
|
|
\fB&em\fI|xx\fR none none - The
|
|
macro \fIxx\fR will be invoked
|
|
when all input has ended.
|
|
The effect is the same as if the contents of \fIxx\fR had been at the end
|
|
of the last file processed.
|
|
.mh
|
|
Number Registers
|
|
.pg
|
|
A variety of parameters are available to the user as
|
|
predefined, named \fInumber registers\fR (see Summary and Index, page 7).
|
|
In addition, the user may define his own named registers.
|
|
Register names are one or two characters long and \fIdo not\fR conflict
|
|
with request, macro, or string names.
|
|
Except for certain predefined read-only registers,
|
|
a number register can be read, written, automatically
|
|
incremented or decremented, and interpolated
|
|
into the input in a variety of formats.
|
|
One common use of user-defined registers is to
|
|
automatically number sections, paragraphs, lines, etc.
|
|
A number register may be used any time numerical input is expected or desired
|
|
and may be used in numerical \fIexpressions\fR (\(sc1.4).
|
|
.pg
|
|
Number registers are created and modified using \fBnr\fR, which
|
|
specifies the name, numerical value, and the auto-increment size.
|
|
Registers are also modified, if accessed
|
|
with an auto-incrementing sequence.
|
|
If the registers \fIx\fR and \fIxx\fR both contain
|
|
\fIN\fR and have the auto-increment size \fIM\fR,
|
|
the following access sequences have the effect shown:
|
|
.TS
|
|
center box;
|
|
c2|c2|c
|
|
c2|c2|c
|
|
l2|c2|c
|
|
l2|c2|c
|
|
l2|l2|c.
|
|
Effect on Value
|
|
Sequence Register Interpolated
|
|
_
|
|
\fB\en\fIx\fR none \fIN\fR
|
|
\fB\en(\fIxx\fR none \fIN\fR
|
|
\fB\en+\fIx\fR \fIx\fR incremented by \fIM\fR \fIN+M\fR
|
|
\fB\en\-\fIx\fR \fIx\fR decremented by \fIM\fR \fIN\-M\fR
|
|
\fB\en+(\fIxx\fR \fIxx\fR incremented by \fIM\fR \fIN+M\fR
|
|
\fB\en\-(\fIxx\fR \fIxx\fR decremented by \fIM\fR \fIN\-M\fR
|
|
.TE
|
|
When interpolated, a number register is converted to
|
|
decimal (default),
|
|
decimal with leading zeros,
|
|
lower-case Roman,
|
|
upper-case Roman,
|
|
lower-case sequential alphabetic,
|
|
or
|
|
upper-case sequential alphabetic
|
|
according to the format specified by \fBaf\fR.
|
|
.h1
|
|
.bt
|
|
\fB&nr\fI|R|\(+-N|M\fR - - \fBu\fR \
|
|
The number register \fIR\fR is assigned the value \fI\(+-N\fR
|
|
with respect to the previous value, if any.
|
|
The increment for auto-incrementing is set to \fIM\fR.
|
|
.bt
|
|
\fB&af\fI|R|c\fR arabic - - Assign format \fIc\fR to register \fIR\fR.
|
|
The available formats are:
|
|
.TS
|
|
center box;
|
|
c2|c
|
|
c2|c
|
|
c2|l.
|
|
Numbering
|
|
Format Sequence
|
|
_
|
|
\fB1\fR 0,1,2,3,4,5,...
|
|
\fB001\fR 000,001,002,003,004,005,...
|
|
\fBi\fR 0,i,ii,iii,iv,v,...
|
|
\fBI\fR 0,I,II,III,IV,V,...
|
|
\fBa\fR 0,a,b,c,...,z,aa,ab,...,zz,aaa,...
|
|
\fBA\fR 0,A,B,C,...,Z,AA,AB,...,ZZ,AAA,...
|
|
.TE
|
|
An arabic format having \fIN\fR digits
|
|
specifies a field width of \fIN\fR digits (example 2 above).
|
|
The read-only registers and the \fIwidth\fR function (\(sc11.2)
|
|
are always arabic.
|
|
.bt
|
|
\fB&rr\fI|R\fR - ignored - Remove register \fIR\fR.
|
|
If many registers are being created dynamically, it
|
|
may become necessary to remove no longer used registers
|
|
to recapture internal storage space for newer registers.
|