1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
.TH TROFF2HTML 1
.SH NAME
troff2html \- convert troff output into HTML
.SH SYNOPSIS
.B troff2html
[
.B -t
.I title
] [
.I file
\ ...
]
.SH DESCRIPTION
.I Troff2html
reads the
.IR troff (1)
output in the named
.IR files ,
default standard input,
and converts them into HTML.
.PP
.I Troff2html
does a tolerable job with straight
.B troff
output, but it is helped by annotations, described below.
Its main use is for
.B man2html
(see Plan 9's \fIhttpd\fR(8)),
which converts
.IR man (1)
pages into HTML
and depends on a specially annotated set of
.IR man (7)
macros, invoked by
.B troff
.BR -manhtml .
.PP
.B Troff
output lines beginning
.IP
.EX
x X html \f1...
.EE
.LP
which are introduced by placing
.B \eX'html\ \f1...\fP'
in the
.IR input ,
cause the rest of the line to be interpolated into the HTML produced.
Several such lines are recognized specially by
.IR troff2html .
The most important are the pair
.IP
.EX
x X html manref start cp 1
x X html manref end cp 1
.EE
.PP
which are used to create HTML hyperlinks around text of the form
.IR cp (1)
pointing to
.BR /magic/man2html/1/cp .
.PP
.I Troff2html
is new and experimental; in time, it may improve and subsume
Plan 9's
\fIms2html\fR(1).
On the one hand, because it uses the input,
.B ms2html
can handle
.IR pic (1),
.IR eqn (1),
etc., which
.I troff2html
does not handle at all; on the other hand,
.B ms2html
understands only
.IR ms (7)
documents and is easily confused by complex
.B troff
constructions.
.I Troff2html
has the reverse properties: it does not handle the preprocessors but its output
is reliable and (modulo helper annotations) is independent of macro package.
.SH SEE ALSO
.IR troff (1),
Plan 9's
\fIms2html\fR(1),
.I man2html
in
Plan 9's
\fIhttpd\fR(8).
.SH BUGS
.B Troff
and HTML have different models, and they don't mesh well in all cases.
.BR Troff 's
indented paragraphs are not well served in HTML, and the output of
.I troff2html
shows this.
|