1999-01-17 15:17:11 +03:00
|
|
|
|
.\" $NetBSD: doc2html,v 1.2 1999/01/17 12:17:11 ross Exp $
|
New macro package for automatically converting -mdoc input to HTML.
Use: nroff -mdoc2html input_file...
Or, for the completely general case,
Use: groff -P-b -P-u -P-o -Tascii -ww -mdoc2html input_file ...
This was originally intended for just the new distrib/notes and other
non-man-page project documentation, but in fact it can get almost all of
the man pages right at this point.
In many cases, I would suggest that original documentation not be written
in HTML or ASCII any more. A good example would be "supported devices".
It's presently duplicated, in the install notes, the web pages, and the
man pages. If written in -mdoc, it can automatically be a man page, a www
page feature, and a printable, downloadable file. We can generate PostScript
and the "unix enhanced text" format used by more(1), as well as plain old
ascii, and all using in-tree tools.
TNF Copyright.
1999-01-13 08:00:28 +03:00
|
|
|
|
.\"
|
|
|
|
|
.\" Copyright (c) 1998, 1999 The NetBSD Foundation, Inc.
|
|
|
|
|
.\" All rights reserved.
|
|
|
|
|
.\"
|
|
|
|
|
.\" This code is derived from software contributed to The NetBSD Foundation
|
|
|
|
|
.\" by Ross Harvey.
|
|
|
|
|
.\"
|
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
|
.\" are met:
|
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
|
.\" 2. 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.
|
|
|
|
|
.\" 3. All advertising materials mentioning features or use of this software
|
|
|
|
|
.\" must display the following acknowledgement:
|
|
|
|
|
.\" This product includes software developed by the NetBSD
|
|
|
|
|
.\" Foundation, Inc. and its contributors.
|
|
|
|
|
.\" 4. Neither the name of The NetBSD Foundation nor the names of its
|
|
|
|
|
.\" contributors may be used to endorse or promote products derived
|
|
|
|
|
.\" from this software without specific prior written permission.
|
|
|
|
|
.\"
|
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, 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 THE FOUNDATION OR CONTRIBUTORS
|
|
|
|
|
.\" 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)
|
|
|
|
|
.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
|
.\" POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
.\"
|
|
|
|
|
.ig
|
|
|
|
|
|
|
|
|
|
The first section of this package processes a large subset of the -mdoc macro
|
|
|
|
|
functions into HTML. All of the commonly used requests are implemented.
|
|
|
|
|
|
|
|
|
|
The second section implements -man (-man.old) macros. These are trivial
|
|
|
|
|
compared to -mdoc.
|
|
|
|
|
|
|
|
|
|
NOTES:
|
|
|
|
|
The initial purpose of these macros is to support distrib/notes.
|
|
|
|
|
It's very close, but not quite ready to do all of the man pages.
|
|
|
|
|
|
|
|
|
|
See src/distrib/notes/Makefile.inc for important groff command
|
|
|
|
|
examples. For HTML generation it is important to turn off overstrike
|
|
|
|
|
modes with -P-b -P-u -P-o.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
TODO:
|
|
|
|
|
There are a few internal macros and other symbols that don't contain
|
|
|
|
|
an embedded `-'.
|
|
|
|
|
|
|
|
|
|
Need a tbl(1) command that generates html tables from tbl(1)
|
|
|
|
|
input. (Partially written.) For now, we just switch into <pre>
|
|
|
|
|
mode on .TS or .PS. Tbl input is very uncommon these days, anyway.
|
|
|
|
|
(-mdoc as the .Bl -column list, which eliminates most requirements
|
|
|
|
|
for tbl)
|
|
|
|
|
|
|
|
|
|
We should probably end all the html pages with an upward
|
|
|
|
|
pointing "contents" link, except right now there is nothing
|
|
|
|
|
to point to.
|
|
|
|
|
|
|
|
|
|
We need "intro" or "contents" pages for each man/man? (man/html?)
|
|
|
|
|
section.
|
|
|
|
|
|
|
|
|
|
WARNING! If you add a callable macro (or define an old one that
|
|
|
|
|
was missing) it MUST have a doc2html@@ alias. (Scan for @@ to see.)
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.de TS
|
|
|
|
|
<pre>
|
|
|
|
|
..
|
|
|
|
|
.de TE
|
|
|
|
|
</pre>
|
|
|
|
|
..
|
|
|
|
|
.de PS
|
|
|
|
|
<pre>
|
|
|
|
|
..
|
|
|
|
|
.de PE
|
|
|
|
|
</pre>
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.nr doc-stackp 0
|
|
|
|
|
.de doc-push
|
|
|
|
|
. ds doc-stack-rq-\\n[doc-stackp] \\$1
|
|
|
|
|
. nr doc-stack-ln-\\n[doc-stackp] \\n[.c]
|
|
|
|
|
. nr doc-stackp +1
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.de doc-pop
|
|
|
|
|
. ie \\n[doc-stackp]<=0 .tm Extraneous \\$1 request at #\\n[.c]
|
|
|
|
|
. el .nr doc-stackp -1
|
|
|
|
|
. ds doc-pop-tmp1 \\*[doc-stack-rq-\\n[doc-stackp]]
|
|
|
|
|
. if !\\*[doc-pop-tmp1]\\$1 \{\
|
|
|
|
|
. tm Need \\*[doc-pop-tmp1] at line \\n[.c] before \\$1
|
|
|
|
|
. tm See line \\n[doc-stack-ln-\\n[doc-stackp]]
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.de doc-rlookup
|
|
|
|
|
. if !r\\$1 \{\
|
|
|
|
|
. ie \\w\\V[\\$1] .nr \\$1 \\V[\\$1]
|
|
|
|
|
. el .nr \\$1 \\$2
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.de doc-slookup
|
|
|
|
|
. if !d\\$1 \{\
|
|
|
|
|
. ie \\w\\V[\\$1] .ds \\$1 \\V[\\$1]
|
|
|
|
|
. el .ds \\$1 \\$2
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.doc-rlookup DOC_DEBUG_MODE 0
|
|
|
|
|
.doc-rlookup DOC_XR 1
|
|
|
|
|
.doc-slookup DOC_MANROOT ..
|
|
|
|
|
.
|
|
|
|
|
.nr in-pre 0
|
|
|
|
|
.nr HTML 1
|
|
|
|
|
.pl 1i
|
|
|
|
|
.po 0
|
|
|
|
|
.in 0
|
|
|
|
|
.nf
|
|
|
|
|
.nh
|
|
|
|
|
.nr list-level 0
|
|
|
|
|
.de ce
|
|
|
|
|
. ie \\$1 \{\
|
|
|
|
|
<center>
|
|
|
|
|
. nr center-on \\$1
|
|
|
|
|
. it 1 doc-center-step
|
|
|
|
|
. \}
|
|
|
|
|
. el . end-center
|
|
|
|
|
..
|
|
|
|
|
.nr center-on 0
|
|
|
|
|
.de end-center
|
|
|
|
|
. it
|
|
|
|
|
. if \\n[center-on] </center>
|
|
|
|
|
. nr center-on 0
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.de doc-center-step
|
|
|
|
|
<br>
|
|
|
|
|
. nr center-on -1
|
|
|
|
|
. ie \\n[center-on]<=0 .end-center
|
|
|
|
|
. el .it 1 doc-center-step
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.ds copy ©
|
|
|
|
|
.ds > >
|
|
|
|
|
.ds < <
|
|
|
|
|
.ds >= >=
|
|
|
|
|
.ds <= <=
|
1999-01-17 15:17:11 +03:00
|
|
|
|
.ds Lt <
|
|
|
|
|
.ds Gt >
|
New macro package for automatically converting -mdoc input to HTML.
Use: nroff -mdoc2html input_file...
Or, for the completely general case,
Use: groff -P-b -P-u -P-o -Tascii -ww -mdoc2html input_file ...
This was originally intended for just the new distrib/notes and other
non-man-page project documentation, but in fact it can get almost all of
the man pages right at this point.
In many cases, I would suggest that original documentation not be written
in HTML or ASCII any more. A good example would be "supported devices".
It's presently duplicated, in the install notes, the web pages, and the
man pages. If written in -mdoc, it can automatically be a man page, a www
page feature, and a printable, downloadable file. We can generate PostScript
and the "unix enhanced text" format used by more(1), as well as plain old
ascii, and all using in-tree tools.
TNF Copyright.
1999-01-13 08:00:28 +03:00
|
|
|
|
.ds & &
|
|
|
|
|
.ds _
|
|
|
|
|
.ds q "
|
|
|
|
|
.ds body-params bgcolor="#FFFFFF" text="#000000"
|
|
|
|
|
.ds Px \\*(tNPOSIX
|
|
|
|
|
.ds document-title
|
|
|
|
|
.ds title-section
|
|
|
|
|
.ds dot-de .de
|
|
|
|
|
.ds dot-dot ..
|
|
|
|
|
.ds sepstring \~
|
|
|
|
|
.ds doc-punct-result
|
|
|
|
|
.ds doc-punct { . , : ; ( ) [ ] }
|
|
|
|
|
.ds close-mode
|
|
|
|
|
.ds recurse-prepend
|
|
|
|
|
.ds doc-anchor
|
|
|
|
|
.ds T " x
|
|
|
|
|
.chop T
|
|
|
|
|
.nr doc-dosep 0
|
|
|
|
|
.nr r-lvl 0
|
|
|
|
|
.
|
|
|
|
|
.if !dMANROOT \{\
|
|
|
|
|
. ds MANROOT \V[MANROOT]
|
|
|
|
|
. if !\w\*[MANROOT] .ds MANROOT ..
|
|
|
|
|
.\}
|
|
|
|
|
.
|
|
|
|
|
.blm Pp
|
|
|
|
|
.
|
|
|
|
|
.
|
|
|
|
|
.de DEBUG
|
|
|
|
|
.if \\n[DOC_DEBUG_MODE] \\$*
|
|
|
|
|
..
|
|
|
|
|
.de Dd
|
|
|
|
|
. as document-title " \\$*
|
|
|
|
|
..
|
|
|
|
|
.de Dt
|
|
|
|
|
. as document-title " \\$*
|
|
|
|
|
..
|
|
|
|
|
.de Os
|
|
|
|
|
. as document-title " \\$*
|
|
|
|
|
. init-html
|
|
|
|
|
..
|
|
|
|
|
.\"
|
|
|
|
|
.\"----------------------------------------------------------------------
|
|
|
|
|
.\" troff requests we translate
|
|
|
|
|
.\"
|
|
|
|
|
.rn br br-real
|
|
|
|
|
.rn sp sp-real
|
|
|
|
|
.rn fi fi-real
|
|
|
|
|
.rn nf nf-real
|
|
|
|
|
.de br
|
|
|
|
|
<br>
|
|
|
|
|
..
|
|
|
|
|
.de sp-nice-try-ross
|
|
|
|
|
. ie !\\n(.$ <br>
|
|
|
|
|
. el .ie '\\$1'1' <br>
|
|
|
|
|
. el \{\
|
|
|
|
|
. if !\\n[in-pre] <pre>
|
|
|
|
|
. nr sp-tmp \\$1v-1v
|
|
|
|
|
. if \\n[sp-tmp]>0 .sp-real \\n[sp-tmp]u
|
|
|
|
|
. if !\\n[in-pre] </pre>
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.\" Although the above probably works, the following is a lot simpler. It
|
|
|
|
|
.\" reduces the request to 1v, but why would you put more than one adjacent
|
|
|
|
|
.\" blank line in an html document anyway?
|
|
|
|
|
.de sp
|
|
|
|
|
. ie \\n[center-on] <!-- -->
|
|
|
|
|
. el <br><br>
|
|
|
|
|
..
|
|
|
|
|
.de end-preformat
|
|
|
|
|
. if \\n[in-pre] </pre>
|
|
|
|
|
. nr in-pre 0
|
|
|
|
|
..
|
|
|
|
|
.de fi
|
|
|
|
|
. end-preformat
|
|
|
|
|
..
|
|
|
|
|
.de nf
|
|
|
|
|
<br>
|
|
|
|
|
<pre>
|
|
|
|
|
. nr in-pre 1
|
|
|
|
|
..
|
|
|
|
|
.\"
|
|
|
|
|
.\"----------------------------------------------------------------------
|
|
|
|
|
.\" Magic to open and close <body> and <html>
|
|
|
|
|
.\"
|
|
|
|
|
.de end-macro
|
|
|
|
|
. br-real \" should be unnecessary...we have fill turned off
|
|
|
|
|
. fl \" more paranoia
|
|
|
|
|
</font></body>
|
|
|
|
|
</html>
|
|
|
|
|
. br-real
|
|
|
|
|
. fl
|
|
|
|
|
..
|
|
|
|
|
.em end-macro
|
|
|
|
|
.de init-html
|
|
|
|
|
<html>
|
|
|
|
|
<title>
|
|
|
|
|
\\*[document-title]
|
|
|
|
|
\\*[title-section]
|
|
|
|
|
</title>
|
|
|
|
|
<body \\*[body-params]>
|
|
|
|
|
\\*[dot-de] init-html
|
|
|
|
|
\\*[dot-dot]
|
|
|
|
|
..
|
|
|
|
|
.de Lk
|
|
|
|
|
. if \\n[.$]<1 .tm #\\n[.c]: Usage: .Lk href [ anchortext/punct ] ...
|
|
|
|
|
. ds doc-href \\$1
|
|
|
|
|
. ds doc-anchortext \\$1
|
|
|
|
|
. shift
|
|
|
|
|
. if \\n[.$] \{\
|
|
|
|
|
. doc-checkpunct \\$1 \\*[doc-punct]
|
|
|
|
|
. if !\\n[doc-ispunct] \{\
|
|
|
|
|
. ds doc-anchortext \\$1
|
|
|
|
|
. shift
|
|
|
|
|
. \}
|
|
|
|
|
. \}
|
|
|
|
|
. ds doc-anchor <a href="\\*[doc-href]">\\*[doc-anchortext]</a>
|
|
|
|
|
. while \\n[.$] \{\
|
|
|
|
|
. doc-checkpunct \\$1 \\*[doc-punct]
|
|
|
|
|
. if !\\n[doc-ispunct] .tm #\\n[.c]: .link ... '$1' -- Huh?
|
|
|
|
|
. as doc-anchor \\$1
|
|
|
|
|
. shift
|
|
|
|
|
. \}
|
|
|
|
|
. ds doc-tmp1 No
|
|
|
|
|
. nr doc-tmp-2 \\w^G\\*[doc-anchortext]^G
|
|
|
|
|
. nr doc-tmp-2 \\n[doc-tmp-2]/\\w'0'
|
|
|
|
|
. if \\n[doc-tmp-2]>=30 .ds doc-tmp1 D1
|
|
|
|
|
. \\*[doc-tmp1] \\*[doc-anchor]
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.\".de mailto
|
|
|
|
|
.\"<a href="mailto:\\$1">\\$1</a>\\$2\\$3\\$4
|
|
|
|
|
.\"..
|
|
|
|
|
.
|
|
|
|
|
.de Ht
|
|
|
|
|
\\$*
|
|
|
|
|
..
|
|
|
|
|
.de Sh
|
|
|
|
|
. end-preformat
|
|
|
|
|
. init-html
|
|
|
|
|
<h1>
|
|
|
|
|
\\$*
|
|
|
|
|
</h1>
|
|
|
|
|
..
|
|
|
|
|
.de Ss
|
|
|
|
|
. end-preformat
|
|
|
|
|
. init-html
|
|
|
|
|
<h2>
|
|
|
|
|
<a name="\\$*">
|
|
|
|
|
\\$*
|
|
|
|
|
</a>
|
|
|
|
|
</h2>
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.de Sx
|
|
|
|
|
. end-preformat
|
|
|
|
|
. ds doc-tmp-1 "\\$1
|
|
|
|
|
. shift
|
|
|
|
|
. while \\n[.$] \{\
|
|
|
|
|
. doc-checkpunct \\$1 \\*[doc-punct]
|
|
|
|
|
. ie !\\n[doc-ispunct] .as doc-tmp-1 " \\$1
|
|
|
|
|
. el .break
|
|
|
|
|
. shift
|
|
|
|
|
. \}
|
|
|
|
|
<a href="#\\*[doc-tmp-1]">\\*[doc-tmp-1]</a>\\$1\\$2\\$3\\$4\\$5\\$6
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.de Pp
|
|
|
|
|
. end-preformat
|
|
|
|
|
<p>
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.nr doc-markbreak 0
|
|
|
|
|
.de doc-conditional-break
|
|
|
|
|
. if \\n[.c]>(\\n[doc-markbreak]+1) <br>
|
|
|
|
|
. nr doc-markbreak \\n[.c]
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.de D1
|
|
|
|
|
. end-preformat
|
|
|
|
|
. doc-conditional-break
|
|
|
|
|
|
|
|
|
|
. No \\$@
|
|
|
|
|
<br>
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.de Dl
|
|
|
|
|
. end-preformat
|
|
|
|
|
. doc-conditional-break
|
|
|
|
|
|
|
|
|
|
. Li \\$@
|
|
|
|
|
<br>
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.de Bd
|
|
|
|
|
. doc-push .Ed
|
|
|
|
|
. end-preformat
|
|
|
|
|
. nr Bd-literal 0
|
|
|
|
|
. nr Bd-offset 0
|
|
|
|
|
. ds get-file
|
|
|
|
|
. while \\n(.$ \{\
|
|
|
|
|
. if '\\$1'-literal' \{\
|
|
|
|
|
. nr Bd-literal 1
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\$1'-offset' \{\
|
|
|
|
|
. shift
|
|
|
|
|
. shift
|
|
|
|
|
. nr Bd-offset 1
|
|
|
|
|
. ds start-display <dl compact><dt><dd>
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\$1'-file' \{\
|
|
|
|
|
. ds get-file so \\$2
|
|
|
|
|
. shift
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. shift
|
|
|
|
|
. \}
|
|
|
|
|
. if \\n[Bd-offset] <dl compact><dt><dd>
|
|
|
|
|
. if \\n[Bd-literal] <code>
|
|
|
|
|
<pre>\\" HOW DO WE GET RID OF THIS NEWLINE??
|
|
|
|
|
.\\*[get-file]
|
|
|
|
|
..
|
|
|
|
|
.de Ed
|
|
|
|
|
</pre>
|
|
|
|
|
. doc-pop .Ed
|
|
|
|
|
. if \\n[Bd-literal] </code>
|
|
|
|
|
. if \\n[Bd-offset] </dl>
|
|
|
|
|
..
|
|
|
|
|
.de Bl
|
|
|
|
|
. doc-push .El
|
|
|
|
|
. end-preformat
|
|
|
|
|
. ds list-start UNKNOWN
|
|
|
|
|
. nr bl-is-compact 0
|
|
|
|
|
. while \\n(.$ \{\
|
|
|
|
|
. if '\\$1'-width' \{\
|
|
|
|
|
. shift
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\$1'-column' \{\
|
|
|
|
|
. ds list-start <center><table>
|
|
|
|
|
. ds list-end </table></center>
|
|
|
|
|
. ds list-tag-prefix <tr><td>
|
|
|
|
|
. ds list-pp-prefix
|
|
|
|
|
. shift
|
|
|
|
|
. break
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\$1'-bullet' \{\
|
|
|
|
|
. ds list-start <ul>
|
|
|
|
|
. ds list-end </ul>
|
|
|
|
|
. ds list-tag-prefix <p>
|
|
|
|
|
. ds list-pp-prefix <li>
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\$1'-dash' \{\
|
|
|
|
|
. ds list-start <dl>
|
|
|
|
|
. ds list-end </dl>
|
|
|
|
|
. ds list-tag-prefix <p>
|
|
|
|
|
. ds list-pp-prefix <dd>-
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\$1'-enum' \{\
|
|
|
|
|
. ds list-start <ol>
|
|
|
|
|
. ds list-end </ol>
|
|
|
|
|
. ds list-tag-prefix <p>
|
|
|
|
|
. ds list-pp-prefix <li>
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\$1'-hyphen' \{\
|
|
|
|
|
. ds list-start <dl>
|
|
|
|
|
. ds list-end </dl>
|
|
|
|
|
. ds list-tag-prefix <p>
|
|
|
|
|
. ds list-pp-prefix <dd>-
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\$1'-item' \{\
|
|
|
|
|
. ds list-start <dl>
|
|
|
|
|
. ds list-end </dl>
|
|
|
|
|
. ds list-tag-prefix <p>
|
|
|
|
|
. ds list-pp-prefix <dd>
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\$1'-tag' \{\
|
|
|
|
|
. ds list-start <dl compact>
|
|
|
|
|
. ds list-end </dl>
|
|
|
|
|
. ds list-tag-prefix <p><dt>
|
|
|
|
|
. ds list-pp-prefix <dd>
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\$1'-diag' \{\
|
|
|
|
|
. ds list-start <dl compact>
|
|
|
|
|
. ds list-end </dl>
|
|
|
|
|
. ds list-tag-prefix <p><dt>
|
|
|
|
|
. ds list-pp-prefix <dd>
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\$1'-hang' \{\
|
|
|
|
|
. ds list-start <dl compact>
|
|
|
|
|
. ds list-end </dl>
|
|
|
|
|
. ds list-tag-prefix <p><dt>
|
|
|
|
|
. ds list-pp-prefix <dd>
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\$1'-ohang' \{\
|
|
|
|
|
. ds list-start <dl>
|
|
|
|
|
. ds list-end </dl>
|
|
|
|
|
. ds list-tag-prefix <p><dt>
|
|
|
|
|
. ds list-pp-prefix <dd>
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\$1'-offset' \{\
|
|
|
|
|
. \" FIXME -- this isn't implemented
|
|
|
|
|
. shift
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\$1'-compact' \{\
|
|
|
|
|
. nr bl-is-compact 1
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\$1'-inset' \{\
|
|
|
|
|
. ds list-start <dl>
|
|
|
|
|
. ds list-end </dl>
|
|
|
|
|
. ds list-tag-prefix <p><dt>
|
|
|
|
|
. ds list-pp-prefix <dd>
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. tm Unknown .Bl list parameter \\$1 (#\\n(.c)
|
|
|
|
|
. break
|
|
|
|
|
. \}
|
|
|
|
|
. if \\n[bl-is-compact] \{\
|
|
|
|
|
. if '\\*[list-tag-prefix]'<p>' .ds list-tag-prefix
|
|
|
|
|
. if '\\*[list-tag-prefix]'<p><dt>' .ds list-tag-prefix <dt>
|
|
|
|
|
. \}
|
|
|
|
|
. if '\\*[list-start]'UNKNOWN' .tm \
|
|
|
|
|
Unknown .Bl list type \\$1 (#\\n(.c)
|
|
|
|
|
. push-list-level start end tag-prefix pp-prefix
|
|
|
|
|
\\*[list-start]
|
|
|
|
|
..
|
|
|
|
|
.de push-list-level
|
|
|
|
|
. nr list-level +1
|
|
|
|
|
. while \\n(.$ \{\
|
|
|
|
|
. ds list-\\$1-\\n[list-level] \\*[list-\\$1]
|
|
|
|
|
. shift
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.de pop-list-level
|
|
|
|
|
. nr list-level -1
|
|
|
|
|
..
|
|
|
|
|
.de It-span
|
|
|
|
|
. end-preformat
|
|
|
|
|
. as doc-pcresult <tr><td colspan=9>
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. as doc-pcresult
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de It
|
|
|
|
|
. end-preformat
|
|
|
|
|
. as doc-pcresult \\*[list-tag-prefix-\\n[list-level]]
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. as doc-pcresult \\*[list-pp-prefix-\\n[list-level]]
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de El
|
|
|
|
|
. doc-pop .El
|
|
|
|
|
\\*[list-end-\\n[list-level]]
|
|
|
|
|
. pop-list-level
|
|
|
|
|
..
|
|
|
|
|
.de Lb
|
|
|
|
|
.if !\\n(.$==1 .tm Usage: .Lb [library name]
|
|
|
|
|
.if "\\$1"libarm32" \&ARM32 Architecture Library (libarm32, -larm32)
|
|
|
|
|
.if "\\$1"libi386" \&i386 Architecture Library (libi386, -li386)
|
|
|
|
|
.if "\\$1"libc" \&Standard C Library (libc, -lc)
|
|
|
|
|
.if "\\$1"libcompat" \&Compatibility Library (libcompat, -lcompat)
|
|
|
|
|
.if "\\$1"libcrypt" \&Crypt Library (libcrypt, -lcrypt)
|
|
|
|
|
.if "\\$1"libcurses" \&Curses Library (libcurses, -lcurses)
|
|
|
|
|
.if "\\$1"libedit" \&Command Line Editor Library (libedit, -ledit)
|
|
|
|
|
.if "\\$1"libkvm" \&Kernel Data Access Library (libkvm, -lkvm)
|
|
|
|
|
.if "\\$1"libm" \&Math Library (libm, -lm)
|
|
|
|
|
.if "\\$1"libossaudio" \&OSS Audio Emulation Library (libossaudio, -lossaudio)
|
|
|
|
|
.if "\\$1"libposix" \&POSIX Compatibility Library (libposix, -lposix)
|
|
|
|
|
.if "\\$1"libresolv" \&DNS Resolver Library (libresolv, -lresolv)
|
|
|
|
|
.if "\\$1"libtermcap" \&Termcap Access Library (libtermcap, -ltermcap)
|
|
|
|
|
.if "\\$1"libutil" \&System Utilities Library (libutil, -lutil)
|
|
|
|
|
.if "\\$1"libz" \&Compression Library (libz, -lz)
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.
|
|
|
|
|
.de doc-checkpunct
|
|
|
|
|
. ds doc-cp-tmp1 \\$1
|
|
|
|
|
. shift
|
|
|
|
|
. nr doc-ispunct 0
|
|
|
|
|
. while \\n[.$] \{\
|
|
|
|
|
. if \\*[doc-cp-tmp1]\\$1 .nr doc-ispunct 1
|
|
|
|
|
. shift
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.\"
|
|
|
|
|
.\" Parsed and Callable macros
|
|
|
|
|
.\"
|
|
|
|
|
.\" Internal structure: `recurse' and `mode-*-{on,off}'
|
|
|
|
|
.\"
|
|
|
|
|
.de recurse
|
|
|
|
|
. nr r-lvl +1
|
|
|
|
|
. ds active-prepend \\*[recurse-prepend]
|
|
|
|
|
.DEBUG .tm r \\n[r-lvl] __\\*[doc-pcresult]==\\$@__
|
|
|
|
|
. while \\n(.$ \{\
|
|
|
|
|
. doc-checkpunct \\$1 \\*[doc-punct]
|
|
|
|
|
. if \\n[doc-ispunct] \{\
|
|
|
|
|
. as doc-punct-result \\$1
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. nr is-request \\A'\\$1'
|
|
|
|
|
. if \\n[is-request] \{\
|
|
|
|
|
. if ddoc2html@@\\$1 .nr is-request 1
|
|
|
|
|
. if !ddoc2html@@\\$1 .nr is-request 0
|
|
|
|
|
. \}
|
|
|
|
|
. ie \\n[is-request] \{\
|
|
|
|
|
. ds recurse-tmp1 \\$1
|
|
|
|
|
. shift
|
|
|
|
|
. if \\w?\\*[active-prepend]?&\\w?\\*[recurse-prepend]? \{\
|
|
|
|
|
. if \\n[doc-dosep] as doc-pcresult \\*[sepstring]
|
|
|
|
|
. as doc-pcresult \\*[active-prepend]
|
|
|
|
|
. nr doc-dosep 0
|
|
|
|
|
. \}
|
|
|
|
|
. ds recurse-prepend
|
|
|
|
|
. \\*[recurse-tmp1] \\$@
|
|
|
|
|
. break
|
|
|
|
|
. \}
|
|
|
|
|
. el \{\
|
|
|
|
|
.DEBUG .tm r \\n[r-lvl] __\\*[doc-pcresult]+\\$1==\\$@__
|
|
|
|
|
. \" a random word, so output saved punctuation
|
|
|
|
|
. \" (normally saved until level 0 mode closure )
|
|
|
|
|
. as doc-pcresult \\*[doc-punct-result]
|
|
|
|
|
. ds doc-punct-result
|
|
|
|
|
. if \\n[doc-dosep] .as doc-pcresult \\*[sepstring]
|
|
|
|
|
. nr doc-dosep 1
|
|
|
|
|
. as doc-pcresult \\*[active-prepend]\\$1
|
|
|
|
|
. ds recurse-prepend
|
|
|
|
|
. shift
|
|
|
|
|
. continue
|
|
|
|
|
. \}
|
|
|
|
|
. \}
|
|
|
|
|
. nr r-lvl -1
|
|
|
|
|
..
|
|
|
|
|
.de make-mode
|
|
|
|
|
\\*[dot-de] mode-\\$1-on
|
|
|
|
|
. DEBUG .tm mode-\\$1-on <\\\\$@>
|
|
|
|
|
. rn close-mode xclose-mode
|
|
|
|
|
. ds close-mode \\$3
|
|
|
|
|
. as doc-pcresult \\\\*[xclose-mode]\\$2
|
|
|
|
|
\\*[dot-dot]
|
|
|
|
|
\\*[dot-de] mode-\\$1-off
|
|
|
|
|
. DEBUG .tm mode-\\$1-off <\\\\$@>
|
|
|
|
|
. as doc-pcresult \\\\*[close-mode]
|
|
|
|
|
. ds close-mode
|
|
|
|
|
\\*[dot-dot]
|
|
|
|
|
..
|
|
|
|
|
.de pc-fin
|
|
|
|
|
. as doc-pcresult \\$1
|
|
|
|
|
. if \\n[r-lvl]=0 \{\\*[doc-pcresult]\\*[doc-punct-result]
|
|
|
|
|
. ds doc-punct-result
|
|
|
|
|
. rm doc-pcresult
|
|
|
|
|
. ds sepstring \~
|
|
|
|
|
. nr doc-dosep 0
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.make-mode bold <b> </b>
|
|
|
|
|
.make-mode code <code> </code>
|
|
|
|
|
.make-mode em <em> </em>
|
|
|
|
|
.make-mode i <i> </i>
|
|
|
|
|
.make-mode caps <font\ size="-1"> <font\ size="+0">
|
|
|
|
|
.am mode-i-on
|
|
|
|
|
. ds sepstring \~
|
|
|
|
|
..
|
|
|
|
|
.am mode-em-on
|
|
|
|
|
. ds sepstring \~
|
|
|
|
|
..
|
|
|
|
|
.am mode-i-off
|
|
|
|
|
. ds sepstring \~
|
|
|
|
|
..
|
|
|
|
|
.am mode-em-off
|
|
|
|
|
. ds sepstring \~
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.de doc-sep-append
|
|
|
|
|
. if \\n[doc-dosep] .as doc-pcresult \~
|
|
|
|
|
. as doc-pcresult \\$1
|
|
|
|
|
. nr doc-dosep 0
|
|
|
|
|
..
|
|
|
|
|
.de No
|
|
|
|
|
. as doc-pcresult \\*[close-mode]
|
|
|
|
|
. ds close-mode
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Fl
|
|
|
|
|
.DEBUG .tm .Fl \\$*
|
|
|
|
|
. mode-bold-on
|
|
|
|
|
. ds recurse-prepend -
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-bold-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Cm
|
|
|
|
|
.DEBUG .tm .Cm \\$*
|
|
|
|
|
. mode-bold-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-bold-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Op
|
|
|
|
|
.DEBUG .tm .Op \\$*
|
|
|
|
|
. as doc-pcresult \&[
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. pc-fin \&]
|
|
|
|
|
..
|
|
|
|
|
.de Em
|
|
|
|
|
.DEBUG .tm .Em \\$*
|
|
|
|
|
. mode-em-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-em-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Fx
|
|
|
|
|
.DEBUG .tm .Fx \\$*
|
|
|
|
|
. as doc-pcresult FreeBSD
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
..
|
|
|
|
|
.de Nm
|
|
|
|
|
. if \\n(.$ \{\
|
|
|
|
|
. ie '\\$1'' .br
|
|
|
|
|
. el \{\
|
|
|
|
|
. ds Nm-save \\$1
|
|
|
|
|
. shift
|
|
|
|
|
. \}
|
|
|
|
|
. \}
|
|
|
|
|
. mode-bold-on
|
|
|
|
|
. as doc-pcresult \\*[Nm-save]
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-bold-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Nd
|
|
|
|
|
.DEBUG .tm .Nd \\$*
|
|
|
|
|
- \\$*
|
|
|
|
|
..
|
|
|
|
|
.de At
|
|
|
|
|
AT&T UNIX\\$*
|
|
|
|
|
..
|
|
|
|
|
.de Lk
|
|
|
|
|
. as doc-pcresult <a href="\\$1">\\$1</a>
|
|
|
|
|
. shift
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Mt
|
|
|
|
|
. as doc-pcresult <a href="mailto:\\$1">\\$1</a>
|
|
|
|
|
. shift
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Ta
|
|
|
|
|
. as doc-pcresult <td>
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Bx
|
|
|
|
|
. doc-checkpunct \\$1 \\*[doc-punct]
|
|
|
|
|
. if !\\n[doc-ispunct] \{\
|
|
|
|
|
. as doc-pcresult \\$1
|
|
|
|
|
. shift
|
|
|
|
|
. \}
|
|
|
|
|
. as doc-pcresult BSD
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Nx
|
|
|
|
|
. as doc-pcresult NetBSD
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Ux
|
|
|
|
|
. as doc-pcresult UNIX
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Ql
|
|
|
|
|
. as doc-pcresult `
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. pc-fin \&'
|
|
|
|
|
..
|
|
|
|
|
.de Pf
|
|
|
|
|
. as doc-pcresult \\$1
|
|
|
|
|
. shift
|
|
|
|
|
. nr doc-dosep 0
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Ns
|
|
|
|
|
. nr doc-dosep 0
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.de doc-start-quote
|
|
|
|
|
. if \\n[r-lvl]&\\n[doc-dosep] .as doc-pcresult \\*[sepstring]
|
|
|
|
|
. as doc-pcresult \\$1
|
|
|
|
|
. nr doc-dosep 0
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.de make-quoter
|
|
|
|
|
\\*[dot-de] \\$1o
|
|
|
|
|
. doc-start-quote \\$2
|
|
|
|
|
. recurse \\\\$@
|
|
|
|
|
. pc-fin
|
|
|
|
|
\\*[dot-dot]
|
|
|
|
|
\\*[dot-de] \\$1c
|
|
|
|
|
. recurse \\\\$@
|
|
|
|
|
. pc-fin \\$3
|
|
|
|
|
\\*[dot-dot]
|
|
|
|
|
\\*[dot-de] \\$1q
|
|
|
|
|
. doc-start-quote \\$2
|
|
|
|
|
. recurse \\\\$@
|
|
|
|
|
. pc-fin \\$3
|
|
|
|
|
\\*[dot-dot]
|
|
|
|
|
..
|
|
|
|
|
.\" generate Aq Ao Ac Bq Bo Bc Dq Do Dc Qq Qo Qc Sq So Sc
|
|
|
|
|
.make-quoter A < >
|
|
|
|
|
.make-quoter B [ ]
|
|
|
|
|
.make-quoter D `` ''
|
|
|
|
|
.make-quoter P ( )
|
|
|
|
|
.make-quoter Q \&" \&"
|
|
|
|
|
.make-quoter S ` '
|
|
|
|
|
.de Ft
|
|
|
|
|
. as doc-pcresult <br><br>
|
|
|
|
|
. mode-code-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-code-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Fn
|
|
|
|
|
. mode-bold-on
|
|
|
|
|
. as doc-pcresult "\\$1
|
|
|
|
|
. shift
|
|
|
|
|
. mode-bold-off
|
|
|
|
|
. as doc-pcresult (
|
|
|
|
|
. mode-code-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-code-off
|
|
|
|
|
. pc-fin )
|
|
|
|
|
..
|
|
|
|
|
.de Fo
|
|
|
|
|
. mode-bold-on
|
|
|
|
|
. as doc-pcresult "\\$1
|
|
|
|
|
. shift
|
|
|
|
|
. mode-bold-off
|
|
|
|
|
. as doc-pcresult (
|
|
|
|
|
. mode-code-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-code-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Fc
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. pc-fin )
|
|
|
|
|
..
|
|
|
|
|
.de Ar
|
|
|
|
|
. mode-i-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-i-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Ic
|
|
|
|
|
. mode-bold-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-bold-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Fa
|
|
|
|
|
. mode-code-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-code-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Xr
|
|
|
|
|
. ie \\n[DOC_XR] \{\
|
|
|
|
|
. mode-code-on
|
|
|
|
|
. as doc-pcresult \\$1(\\$2)
|
|
|
|
|
. mode-code-off
|
|
|
|
|
. \}
|
|
|
|
|
. el \{\
|
|
|
|
|
. as doc-pcresult <a href="\\*[DOC_MANROOT]/html\\$2/m_\\$1.html">
|
|
|
|
|
. as doc-pcresult \\$1(\\$2)</a>
|
|
|
|
|
. \}
|
|
|
|
|
. shift
|
|
|
|
|
. shift
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Dv
|
|
|
|
|
. mode-code-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-code-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Ic
|
|
|
|
|
. mode-bold-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-bold-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Pa
|
|
|
|
|
. mode-code-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-code-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Tn
|
|
|
|
|
. mode-caps-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-caps-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Fd
|
|
|
|
|
. as doc-pcresult <br>
|
|
|
|
|
. mode-bold-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-bold-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Va
|
|
|
|
|
. mode-i-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-i-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Li
|
|
|
|
|
. mode-code-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-code-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Sy
|
|
|
|
|
. mode-bold-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-bold-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Me
|
|
|
|
|
. mode-bold-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-bold-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Ev
|
|
|
|
|
. mode-code-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-code-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de Cd
|
|
|
|
|
. mode-bold-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-bold-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.ig
|
|
|
|
|
I used to have a caps-code mode for Er. But <code> apparently
|
|
|
|
|
already implies a small mode or maybe actually small caps mode.
|
|
|
|
|
..
|
|
|
|
|
.de Er
|
|
|
|
|
. mode-code-on
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. mode-code-off
|
|
|
|
|
. pc-fin
|
|
|
|
|
..
|
|
|
|
|
.de St
|
|
|
|
|
. ie \\n(.$==0 \{\
|
|
|
|
|
. tm The .St (expand standard name) macro requires >= 1 arg
|
|
|
|
|
. \}
|
|
|
|
|
. el \{\
|
|
|
|
|
. ds std-tmp1 ERROR
|
|
|
|
|
. if "\\$1"-p1003.1-96" \{\
|
|
|
|
|
. ds std-tmp1 \&IEEE Std1003.1-1996
|
|
|
|
|
. as std-tmp1 " \"exactly one space
|
|
|
|
|
. as std-tmp1 (``\\*(Px'')
|
|
|
|
|
. \}
|
|
|
|
|
. if "\\$1"-p1003.1c-95" \{\
|
|
|
|
|
. ds std-tmp1 \&IEEE Std1003.1c-1995
|
|
|
|
|
. as std-tmp1 " \"exactly one space
|
|
|
|
|
. as std-tmp1 (``\\*(Px'')
|
|
|
|
|
. \}
|
|
|
|
|
. if "\\$1"-p1003.1b-93" \{\
|
|
|
|
|
. ds std-tmp1 \&IEEE Std1003.1b-1993
|
|
|
|
|
. as std-tmp1 " \"exactly one space
|
|
|
|
|
. as std-tmp1 (``\\*(Px'')
|
|
|
|
|
. \}
|
|
|
|
|
. if "\\$1"-p1003.1-90" \{\
|
|
|
|
|
. ds std-tmp1 \&IEEE Std1003.1-1990
|
|
|
|
|
. as std-tmp1 " \"exactly one space
|
|
|
|
|
. as std-tmp1 (``\\*(Px'')
|
|
|
|
|
. \}
|
|
|
|
|
. if "\\$1"-p1003.1-88" \{\
|
|
|
|
|
. ds std-tmp1 \&IEEE Std1003.1-1988
|
|
|
|
|
. as std-tmp1 " \"exactly one space
|
|
|
|
|
. as std-tmp1 (``\\*(Px'')
|
|
|
|
|
. \}
|
|
|
|
|
. if "\\$1"-p1003.1" \{\
|
|
|
|
|
. ds std-tmp1 \&IEEE Std1003.1
|
|
|
|
|
. as std-tmp1 " \"exactly one space
|
|
|
|
|
. as std-tmp1 (``\\*(Px'')
|
|
|
|
|
. \}
|
|
|
|
|
. if "\\$1"-p1003.2-92" \{\
|
|
|
|
|
. ds std-tmp1 \&IEEE Std1003.2-1992
|
|
|
|
|
. as std-tmp1 " \"exactly one space
|
|
|
|
|
. as std-tmp1 (``\\*(Px.2'')
|
|
|
|
|
. \}
|
|
|
|
|
. if "\\$1"-p1003.2" \{\
|
|
|
|
|
. ds std-tmp1 \&IEEE Std1003.2
|
|
|
|
|
. as std-tmp1 " \"exactly one space
|
|
|
|
|
. as std-tmp1 (``\\*(Px.2'')
|
|
|
|
|
. \}
|
|
|
|
|
. if "\\$1"-ansiC" \{\
|
|
|
|
|
. ds std-tmp1 \&ANSI X3.159-1989
|
|
|
|
|
. as std-tmp1 " \"exactly one space
|
|
|
|
|
. as std-tmp1 (``ANSI C'')
|
|
|
|
|
. \}
|
|
|
|
|
. if "\\$1"-ansiC-89" \{\
|
|
|
|
|
. ds std-tmp1 \&ANSI X3.159-1989
|
|
|
|
|
. as std-tmp1 " \"exactly one space
|
|
|
|
|
. as std-tmp1 (``ANSI C'')
|
|
|
|
|
. \}
|
|
|
|
|
. if "\\$1"-ieee754" \{\
|
|
|
|
|
. ds std-tmp1 \&IEEE Std754-1985
|
|
|
|
|
. \}
|
|
|
|
|
. if "\\$1"-iso8802-3" \{\
|
|
|
|
|
. ds std-tmp1 \&ISO 8802-3: 1989
|
|
|
|
|
. \}
|
|
|
|
|
. if "\\$1"-xpg3" \{\
|
|
|
|
|
. ds std-tmp1 \&X/Open Portability Guide Issue 3
|
|
|
|
|
. as std-tmp1 " \"exactly one space
|
|
|
|
|
. as std-tmp1 (``XPG3'')
|
|
|
|
|
. \}
|
|
|
|
|
. if "\\$1"-xpg4" \{\
|
|
|
|
|
. ds std-tmp1 \&X/Open Portability Guide Issue 4
|
|
|
|
|
. as std-tmp1 " \"exactly one space
|
|
|
|
|
. as std-tmp1 (``XPG4'')
|
|
|
|
|
. \}
|
|
|
|
|
. if "\\$1"-xpg4.2" \{\
|
|
|
|
|
. ds std-tmp1 \&X/Open Portability Guide Issue 4.2
|
|
|
|
|
. as std-tmp1 " \"exactly one space
|
|
|
|
|
. as std-tmp1 (``XPG4.2'')
|
|
|
|
|
. \}
|
|
|
|
|
. if "\\*[std-tmp1]"ERROR" .tm ERROR, no such std: .St \\$*
|
|
|
|
|
. shift
|
|
|
|
|
. as doc-pcresult \~\\*[std-tmp1]\~
|
|
|
|
|
. recurse \\$@
|
|
|
|
|
. pc-fin
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.ig
|
|
|
|
|
I've observed that <code> does decent things with caps, and it should
|
|
|
|
|
be reminiscent of the old typewriter-style unix logos.
|
|
|
|
|
..
|
|
|
|
|
.de At
|
|
|
|
|
. if \\n(.$==2 \{\
|
|
|
|
|
. if "\\$1"32v" Version 32V <code>AT&T UNIX</code>\\$2
|
|
|
|
|
. if "\\$1"V" \<code>AT&T</code> System V <code>UNIX</code>\\$2
|
|
|
|
|
. if "\\$1"V.1" <code>AT&T</code> System V.1 <code>UNIX</code>\\$2
|
|
|
|
|
. if "\\$1"V.2" <code>AT&T</code> System V.2 <code>UNIX</code>\\$2
|
|
|
|
|
. if "\\$1"V.3" <code>AT&T</code> System V.3 <code>UNIX</code>\\$2
|
|
|
|
|
. if "\\$1"V.4" <code>AT&T</code> System V.4 <code>UNIX</code>\\$2
|
|
|
|
|
. if "\\$1"v5" Version 5 <code>AT&T UNIX</code>\\$2
|
|
|
|
|
. if "\\$1"v6" Version 6 <code>AT&T UNIX</code>\\$2
|
|
|
|
|
. if "\\$1"v7" Version 7 <code>AT&T UNIX</code>\\$2
|
|
|
|
|
. \}
|
|
|
|
|
. if \\n(.$==1 \{\
|
|
|
|
|
. if "\\$1"32v" Version 32V <code>AT&T UNIX</code>
|
|
|
|
|
. if "\\$1"V" <code>AT&T</code> System V <code>UNIX</code>
|
|
|
|
|
. if "\\$1"V.1" <code>AT&T</code> System V.1 <code>UNIX</code>
|
|
|
|
|
. if "\\$1"V.2" <code>AT&T</code> System V.2 <code>UNIX</code>
|
|
|
|
|
. if "\\$1"V.3" <code>AT&T</code> System V.3 <code>UNIX</code>
|
|
|
|
|
. if "\\$1"V.4" <code>AT&T</code> System V.4 <code>UNIX</code>
|
|
|
|
|
. if "\\$1"v6" Version 6 <code>AT&T UNIX</code>
|
|
|
|
|
. if "\\$1"v7" Version 7 <code>AT&T UNIX</code>
|
|
|
|
|
. \}
|
|
|
|
|
. if \\n(.$==0 \{\
|
|
|
|
|
. if 1 <code>AT&T UNIX</code>
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.\"----------------------------------------------------------------------
|
|
|
|
|
.\"
|
|
|
|
|
.\" There must be a doc2html alias for all callable macros
|
|
|
|
|
.\"
|
|
|
|
|
.als doc2html@@Dd Dd
|
|
|
|
|
.als doc2html@@Dt Dt
|
|
|
|
|
.als doc2html@@Os Os
|
|
|
|
|
.als doc2html@@br br
|
|
|
|
|
.als doc2html@@sp sp
|
|
|
|
|
.als doc2html@@fi fi
|
|
|
|
|
.als doc2html@@nf nf
|
|
|
|
|
.als doc2html@@Sh Sh
|
|
|
|
|
.als doc2html@@Ss Ss
|
|
|
|
|
.als doc2html@@Pp Pp
|
|
|
|
|
.als doc2html@@D1 D1
|
|
|
|
|
.als doc2html@@Dl Dl
|
|
|
|
|
.als doc2html@@Bd Bd
|
|
|
|
|
.als doc2html@@Ed Ed
|
|
|
|
|
.als doc2html@@Bl Bl
|
|
|
|
|
.als doc2html@@It It
|
|
|
|
|
.als doc2html@@El El
|
|
|
|
|
.als doc2html@@Fl Fl
|
|
|
|
|
.als doc2html@@Cm Cm
|
|
|
|
|
.als doc2html@@Op Op
|
|
|
|
|
.als doc2html@@Em Em
|
|
|
|
|
.als doc2html@@Fx Fx
|
|
|
|
|
.als doc2html@@Nm Nm
|
|
|
|
|
.als doc2html@@Nd Nd
|
|
|
|
|
.als doc2html@@At At
|
|
|
|
|
.als doc2html@@Bx Bx
|
|
|
|
|
.als doc2html@@Nx Nx
|
|
|
|
|
.als doc2html@@Ux Ux
|
|
|
|
|
.als doc2html@@Ql Ql
|
|
|
|
|
.als doc2html@@Pf Pf
|
|
|
|
|
.als doc2html@@Ns Ns
|
|
|
|
|
.als doc2html@@Ft Ft
|
|
|
|
|
.als doc2html@@Fn Fn
|
|
|
|
|
.als doc2html@@Fo Fo
|
|
|
|
|
.als doc2html@@Fc Fc
|
|
|
|
|
.als doc2html@@Ar Ar
|
|
|
|
|
.als doc2html@@Ic Ic
|
|
|
|
|
.als doc2html@@Fa Fa
|
|
|
|
|
.als doc2html@@Xr Xr
|
|
|
|
|
.als doc2html@@Dv Dv
|
|
|
|
|
.als doc2html@@Ic Ic
|
|
|
|
|
.als doc2html@@Pa Pa
|
|
|
|
|
.als doc2html@@Tn Tn
|
|
|
|
|
.als doc2html@@Fd Fd
|
|
|
|
|
.als doc2html@@Va Va
|
|
|
|
|
.als doc2html@@Li Li
|
|
|
|
|
.als doc2html@@Sy Sy
|
|
|
|
|
.als doc2html@@Me Me
|
|
|
|
|
.als doc2html@@Ev Ev
|
|
|
|
|
.als doc2html@@Cd Cd
|
|
|
|
|
.als doc2html@@St St
|
|
|
|
|
.als doc2html@@Er Er
|
|
|
|
|
.als doc2html@@Aq Aq
|
|
|
|
|
.als doc2html@@Ao Ao
|
|
|
|
|
.als doc2html@@Ac Ac
|
|
|
|
|
.als doc2html@@Bq Bq
|
|
|
|
|
.als doc2html@@Bo Bo
|
|
|
|
|
.als doc2html@@Bc Bc
|
|
|
|
|
.als doc2html@@Dq Dq
|
|
|
|
|
.als doc2html@@Do Do
|
|
|
|
|
.als doc2html@@Dc Dc
|
|
|
|
|
.als doc2html@@Qq Qq
|
|
|
|
|
.als doc2html@@Qo Qo
|
|
|
|
|
.als doc2html@@Qc Qc
|
|
|
|
|
.als doc2html@@Sq Sq
|
|
|
|
|
.als doc2html@@So So
|
|
|
|
|
.als doc2html@@Sc Sc
|
|
|
|
|
.als doc2html@@Ta Ta
|
|
|
|
|
.als doc2html@@Mt Mt
|
|
|
|
|
.als doc2html@@Lk Lk
|
|
|
|
|
.als doc2html@@No No
|
|
|
|
|
.
|
|
|
|
|
.rn em doc-real-em
|
|
|
|
|
.de em
|
|
|
|
|
. tm End-macro (.em) respecification is not allowed. (#\\n(.c)
|
|
|
|
|
. tm Should this have been .Em ...?
|
|
|
|
|
..
|
|
|
|
|
.
|
|
|
|
|
.ig
|
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
|
THESE ARE THE -man (-man.old) MACRO FUNCTIONS
|
|
|
|
|
|
|
|
|
|
Internal symbols relating to -man are prefixed with mo-
|
|
|
|
|
The body-params string used with -mdoc2html is used here as well.
|
|
|
|
|
..
|
|
|
|
|
.de TH
|
|
|
|
|
<html>
|
|
|
|
|
<title>
|
|
|
|
|
\\$*
|
|
|
|
|
.nr mo-section \\$2
|
|
|
|
|
</title>
|
|
|
|
|
<body \\*[body-params]>
|
|
|
|
|
..
|
|
|
|
|
.de SH
|
|
|
|
|
. end-preformat
|
|
|
|
|
. mo-end-dl
|
|
|
|
|
<h1> \\$* </h1>
|
|
|
|
|
..
|
|
|
|
|
.de SS
|
|
|
|
|
. end-preformat
|
|
|
|
|
. mo-end-dl
|
|
|
|
|
<h3> \\$* </h3>
|
|
|
|
|
..
|
|
|
|
|
.de B
|
|
|
|
|
. ie \\n(.$ <b>\&\\$*</b>
|
|
|
|
|
. el \{\
|
|
|
|
|
. if 1 <b>
|
|
|
|
|
. it 1 mo-end-bold
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.de I
|
|
|
|
|
. it 1 mo-end-italic
|
|
|
|
|
. ie \\n(.$ <i>\&\\$*</i>
|
|
|
|
|
. el \{\
|
|
|
|
|
. if 1 <i>
|
|
|
|
|
. it 1 mo-end-bold
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.de mo-end-bold
|
|
|
|
|
</b>
|
|
|
|
|
..
|
|
|
|
|
.de mo-end-italic
|
|
|
|
|
</i>
|
|
|
|
|
..
|
|
|
|
|
.de SM
|
|
|
|
|
<font size=-1>
|
|
|
|
|
. it 1 mo-end-smallcaps
|
|
|
|
|
. if \\n(.$ \&\\$*
|
|
|
|
|
..
|
|
|
|
|
.de mo-end-smallcaps
|
|
|
|
|
<font size=+0>
|
|
|
|
|
..
|
|
|
|
|
.de BI
|
|
|
|
|
. mo-try-link \\$1 \\$2
|
|
|
|
|
. if !\\n[mo-did-link] \{\
|
|
|
|
|
. ds mo-bi-tmp1
|
|
|
|
|
. while \\n(.$>=2 \{\
|
|
|
|
|
. as mo-bi-tmp1 <b>\\$1</b><i>\\$2</i>
|
|
|
|
|
. shift
|
|
|
|
|
. shift
|
|
|
|
|
. \}
|
|
|
|
|
. as mo-bi-tmp1 \\$*
|
|
|
|
|
\&\\*[mo-bi-tmp1]
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.de BR
|
|
|
|
|
. mo-try-link \\$1 \\$2
|
|
|
|
|
. if !\\n[mo-did-link] \{\
|
|
|
|
|
. ds mo-bi-tmp1
|
|
|
|
|
. while \\n(.$>=2 \{\
|
|
|
|
|
. as mo-bi-tmp1 <b>\\$1</b>\\$2
|
|
|
|
|
. shift
|
|
|
|
|
. shift
|
|
|
|
|
. \}
|
|
|
|
|
. as mo-bi-tmp1 \\$*
|
|
|
|
|
\&\\*[mo-bi-tmp1]
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.de IB
|
|
|
|
|
. mo-try-link \\$1 \\$2
|
|
|
|
|
. if !\\n[mo-did-link] \{\
|
|
|
|
|
. ds mo-bi-tmp1
|
|
|
|
|
. while \\n(.$>=2 \{\
|
|
|
|
|
. as mo-bi-tmp1 <i>\\$1</i><b>\\$2</b>
|
|
|
|
|
. shift
|
|
|
|
|
. shift
|
|
|
|
|
. \}
|
|
|
|
|
. as mo-bi-tmp1 \\$*
|
|
|
|
|
\&\\*[mo-bi-tmp1]
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.de IR
|
|
|
|
|
. mo-try-link \\$1 \\$2
|
|
|
|
|
. if !\\n[mo-did-link] \{\
|
|
|
|
|
. ds mo-bi-tmp1
|
|
|
|
|
. while \\n(.$>=2 \{\
|
|
|
|
|
. as mo-bi-tmp1 <i>\\$1</i>\\$2
|
|
|
|
|
. shift
|
|
|
|
|
. shift
|
|
|
|
|
. \}
|
|
|
|
|
. as mo-bi-tmp1 \\$*
|
|
|
|
|
\&\\*[mo-bi-tmp1]
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.de CT
|
|
|
|
|
\&<<font size=-1>CTRL/<font size=+0>\\$*>
|
|
|
|
|
..
|
|
|
|
|
.de DS
|
|
|
|
|
<code><pre>
|
|
|
|
|
..
|
|
|
|
|
.de DE
|
|
|
|
|
</pre></code>
|
|
|
|
|
..
|
|
|
|
|
.als Ds DS
|
|
|
|
|
.als De DE
|
|
|
|
|
.als EX DS
|
|
|
|
|
.als EE DE
|
|
|
|
|
.de TP
|
|
|
|
|
. mo-start-dl
|
|
|
|
|
<dt>
|
|
|
|
|
. it 1 mo-dd
|
|
|
|
|
..
|
|
|
|
|
.de IP
|
|
|
|
|
. mo-start-dl
|
|
|
|
|
<dt>
|
|
|
|
|
<b>\\$1</b>
|
|
|
|
|
. it 1 mo-dd
|
|
|
|
|
..
|
|
|
|
|
.de mo-start-dl
|
|
|
|
|
. end-preformat
|
|
|
|
|
. if !\\n[mo-in-dl] <dl compact>
|
|
|
|
|
. nr mo-in-dl 1
|
|
|
|
|
..
|
|
|
|
|
.de mo-dd
|
|
|
|
|
<dd>
|
|
|
|
|
..
|
|
|
|
|
.de mo-end-dl
|
|
|
|
|
. if \\n[mo-in-dl] </dl>
|
|
|
|
|
. nr mo-in-dl 0
|
|
|
|
|
..
|
|
|
|
|
.de P
|
|
|
|
|
. end-preformat
|
|
|
|
|
. mo-end-dl
|
|
|
|
|
<p>
|
|
|
|
|
..
|
|
|
|
|
.als PP P
|
|
|
|
|
.als LP P
|
|
|
|
|
.de mo-try-link
|
|
|
|
|
. nr mo-did-link 0
|
|
|
|
|
. if \\A'\\$2' \{\
|
|
|
|
|
. if \\w'\\*[\\$2]' \{\
|
|
|
|
|
. Xr \\$1 \\*[\\$2]
|
|
|
|
|
. nr mo-did-link 1
|
|
|
|
|
. \}
|
|
|
|
|
. \}
|
|
|
|
|
..
|
|
|
|
|
.ds (1) 1
|
|
|
|
|
.ds (2) 2
|
|
|
|
|
.ds (3) 3
|
|
|
|
|
.ds (4) 4
|
|
|
|
|
.ds (5) 5
|
|
|
|
|
.ds (6) 6
|
|
|
|
|
.ds (7) 7
|
|
|
|
|
.ds (8) 8
|
|
|
|
|
.ds (9) 9
|
|
|
|
|
.ds (1), 1
|
|
|
|
|
.ds (2), 2
|
|
|
|
|
.ds (3), 3
|
|
|
|
|
.ds (4), 4
|
|
|
|
|
.ds (5), 5
|
|
|
|
|
.ds (6), 6
|
|
|
|
|
.ds (7), 7
|
|
|
|
|
.ds (8), 8
|
|
|
|
|
.ds (9), 9
|
|
|
|
|
.ds (1). 1
|
|
|
|
|
.ds (2). 2
|
|
|
|
|
.ds (3). 3
|
|
|
|
|
.ds (4). 4
|
|
|
|
|
.ds (5). 5
|
|
|
|
|
.ds (6). 6
|
|
|
|
|
.ds (7). 7
|
|
|
|
|
.ds (8). 8
|
|
|
|
|
.ds (9). 9
|