Oh, and now the text backend warns about too-long code lines, I'd
[sgt/halibut] / doc / output.but
CommitLineData
16ea3abe 1\C{output} Halibut output formats
2
339cbe09 3This chapter describes each of Halibut's current \i{output formats}.
4It gives some general information about the format, and also
5describes all the \i{configuration directives} which are specific to
6that format.
16ea3abe 7
8\H{output-text} Plain text
9
339cbe09 10This output format generates the document as a single \i{plain text}
0a6347b4 11file.
16ea3abe 12
339cbe09 13The output file is currently assumed to be in the \i{ISO 8859-1}
16ea3abe 14character set. Any Unicode characters representable in this set will
15be output verbatim; any other characters will not be output and
339cbe09 16their \i{fallback text} (if any) will be used instead.
16ea3abe 17
18The precise formatting of the text file can be controlled by a
19variety of configuration directives. They are listed in the
20following subsections.
21
0a6347b4 22\S{output-text-file} Output file name
23
24\dt \I{\cw{\\cfg\{text-filename\}}}\cw{\\cfg\{text-filename\}\{}\e{filename}\cw{\}}
25
26\dd Sets the \i{output file name} in which to store the text file.
27This directive is implicitly generated if you provide a file name
28parameter after the command-line option \i\c{--text} (see
29\k{running-options}).
30
16ea3abe 31\S{output-text-dimensions} Indentation and line width
32
33This section describes the configuration directives which control
339cbe09 34the \i{horizontal dimensions} of the output text file: how much
16ea3abe 35paragraphs are indented by and how long the lines are.
36
339cbe09 37\dt \I{\cw{\\cfg\{text-width\}}}\cw{\\cfg\{text-width\}\{}\e{width}\cw{\}}
16ea3abe 38
339cbe09 39\dd Sets the \I{text width}width of the main part of the document,
40in characters. This width will be used for wrapping paragraphs and
41for centring titles (if you have asked for titles to be centred -
42see \k{output-text-headings}). This width does \e{not} include the
43left indentation set by \cw{\\cfg\{text-indent\}}; if you specify an
16ea3abe 44indent of 8 and a width of 64, your maximum output line length will
45be 72.
46
339cbe09 47\dt \I{\cw{\\cfg\{text-indent\}}}\cw{\\cfg\{text-indent\}\{}\e{indent}\cw{\}}
16ea3abe 48
339cbe09 49\dd Sets the left \i{indentation} for the document. If you set this
50to zero, your document will look like an ordinary text file as
51someone with a text editor might have written it; if you set it
52above zero, the text file will have a \i{margin} down the left in
53the style of some printed manuals, and you can then configure the
54section numbers to appear in this margin (see
55\k{output-text-headings}).
16ea3abe 56
339cbe09 57\dt \I{\cw{\\cfg\{text-indent-code\}}}\cw{\\cfg\{text-indent-code\}\{}\e{indent}\cw{\}}
16ea3abe 58
59\dd Specifies how many extra characters of indentation (on top of
339cbe09 60the normal left indent) should be given to \I{code paragraphs,
61indentation} code paragraphs.
16ea3abe 62
339cbe09 63\dt \I{\cw{\\cfg\{text-list-indent\}}}\cw{\\cfg\{text-list-indent\}\{}\e{indent}\cw{\}}
16ea3abe 64
65\dd Specifies how many extra spaces should be used to indent the
339cbe09 66bullet or number in a \I{bulletted list, indentation}bulletted or
67\I{numbered list, indentation}numbered \I{list, indentation}list.
68The actual body of the list item will be indented by this much
69\e{plus} the value configured by \cw{\\cfg\{text-listitem-indent\}}.
16ea3abe 70
339cbe09 71\dt \I{\cw{\\cfg\{text-listitem-indent\}}}\cw{\\cfg\{text-listitem-indent\}\{}\e{indent}\cw{\}}
16ea3abe 72
73\dd Specifies how many extra spaces should be used to indent the
74body of a list item, over and above the number configured in
75\cw{\\cfg\{text-list-indent\}}.
76
339cbe09 77\dt \I{\cw{\\cfg\{text-indent-preamble\}}}\cw{\\cfg\{text-indent-preamble\}\{}\e{boolean}\cw{\}}
16ea3abe 78
339cbe09 79\dd When this is set to \c{true}, the document \i{preamble} (i.e. any
16ea3abe 80paragraphs appearing before the first chapter heading) will be
81indented to the level specified by \cw{\\cfg\{text-indent\}}. If
82this setting is \c{false}, the document preamble will not be
83indented at all from the left margin.
84
339cbe09 85\S{output-text-headings} \ii{Configuring heading display}
16ea3abe 86
87The directives in this section allow you to configure the appearance
88of the title, chapter and section headings in your text file.
89
339cbe09 90Several of the directives listed below specify the \i{alignment} of
91a heading. These alignment options have three possible values:
16ea3abe 92
339cbe09 93\dt \i\c{left}
16ea3abe 94
95\dd Align the heading to the very left of the text file (column zero).
96
339cbe09 97\dt \i\c{leftplus}
16ea3abe 98
99\dd Align the section title to the left of the main display region
100(in other words, indented to the level specified by
101\cw{\\cfg\{text-indent\}}). The section \e{number} is placed to the
102left of that (so that it goes in the margin if there is room).
103
339cbe09 104\dt \i\c{centre}
16ea3abe 105
106\dd Centre the heading.
107
108Also, several of the directives below specify how a title should be
339cbe09 109\I{underlining}underlined. The parameter to one of these directives
db662ca1 110should be either blank (\cw{\{\}}) or a piece of text which will be
111repeated to produce the underline. So you might want to specify, for
112example, \cw{\\text-title-underline\{=\}} but
113\cw{\\text-chapter-underline\{\-\}}.
114
115You can also specify more than one underline setting, and Halibut
116will choose the first one that the output character set supports.
117So, for example, you could write
118\cw{\\text-chapter-underline\{\u203e\}\{\-\}}, and Halibut would use
119the Unicode \q{OVERLINE} character where possible and fall back to
120the ASCII minus sign otherwise.
16ea3abe 121
339cbe09 122\dt \I{\cw{\\cfg\{text-title-align\}}}\cw{\\cfg\{text-title-align\}\{}\e{alignment}\cw{\}}
16ea3abe 123
124\dd Specifies the alignment of the overall document title: \c{left},
125\c{leftplus} or \c{centre}.
126
339cbe09 127\dt \I{\cw{\\cfg\{text-title-underline\}}}\cw{\\cfg\{text-title-underline\}\{}\e{underline-character}\cw{\}}
16ea3abe 128
129\dd Specifies how the overall document title should be underlined.
130
339cbe09 131\dt \I{\cw{\\cfg\{text-chapter-align\}}}\cw{\\cfg\{text-chapter-align\}\{}\e{alignment}\cw{\}}
16ea3abe 132
133\dd Specifies the alignment of chapter and appendix headings.
134
339cbe09 135\dt \I{\cw{\\cfg\{text-chapter-underline\}}}\cw{\\cfg\{text-chapter-underline\}\{}\e{underline-character}\cw{\}}
16ea3abe 136
137\dd Specifies how chapter and appendix headings should be underlined.
138
339cbe09 139\dt \I{\cw{\\cfg\{text-chapter-numeric\}}}\cw{\\cfg\{text-chapter-numeric\}\{}\e{boolean}\cw{\}}
16ea3abe 140
141\dd If this is set to \c{true}, then chapter headings will not
142contain the word \q{Chapter} (or whatever other word you have
143defined in its place - see \k{input-sections} and \k{input-config});
144they will just contain the chapter \e{number}, followed by the
145chapter title. If you set this to \c{false}, chapter headings will
146be prefixed by \q{Chapter} or equivalent.
147
339cbe09 148\dt \I{\cw{\\cfg\{text-chapter-suffix\}}}\cw{\\cfg\{text-chapter-suffix\}\{}\e{text}\cw{\}}
16ea3abe 149
150\dd This specifies the suffix text to be appended to the chapter
151number, before displaying the chapter title. For example, if you set
152this to \q{\cw{:\_}}, then the chapter title might look something
153like \q{Chapter 2: Doing Things}.
154
339cbe09 155\dt \I{\cw{\\cfg\{text-section-align\}}}\cw{\\cfg\{text-section-align\}\{}\e{level}\cw{\}\{}\e{alignment}\cw{\}}
16ea3abe 156
157\dd Specifies the alignment of section headings at a particular
158level. The \e{level} parameter specifies which level of section
159headings you want to affect: 0 means first-level headings (\c{\\H}),
1601 means second-level headings (\c{\\S}), 2 means the level below
161that (\c{\\S2}), and so on. The \e{alignment} parameter is treated
162just like the other alignment directives listed above.
163
339cbe09 164\dt \I{\cw{\\cfg\{text-section-underline\}}}\cw{\\cfg\{text-section-underline\}\{}\e{level}\cw{\}\{}\e{underline-character}\cw{\}}
16ea3abe 165
166\dd Specifies how to underline section headings at a particular level.
167
339cbe09 168\dt \I{\cw{\\cfg\{text-section-numeric\}}}\cw{\\cfg\{text-section-numeric\}\{}\e{level}\cw{\}\{}\e{boolean}\cw{\}}
16ea3abe 169
170\dd Specifies whether section headings at a particular level should
171contain the word \q{Section} or equivalent (if \c{false}), or should
172be numeric only (if \c{true}).
173
339cbe09 174\dt \I{\cw{\\cfg\{text-section-suffix\}}}\cw{\\cfg\{text-section-suffix\}\{}\e{level}\cw{\}\{}\e{text}\cw{\}}
16ea3abe 175
339cbe09 176\dd Specifies the \I{suffix text, in section titles}suffix text to
177be appended to section numbers at a particular level, before
178displaying the section title.
16ea3abe 179
db662ca1 180\S{output-text-characters} Configuring the characters used
181
182\dt \I{\cw{\\cfg\{text-bullet\}}}\cw{\\cfg\{text-bullet\}\{}\e{text}\cw{\}}[\cw{\{}\e{text}...\cw{\}}]
183
184\dd This specifies the text which should be used as the \i{bullet}
185in bulletted lists. It can be one character
186(\cw{\\cfg\{text-bullet\}\{-\}}), or more than one
187(\cw{\\cfg\{text-bullet\}\{(*)\}}).
188
189\lcont{
190
191You can specify multiple possible options (each in their own pair of
192braces) after this command, and Halibut will choose the first one
193which the output character set supports. (This is to allow you to
194configure the bullet character once, generate output in several
195different character sets, and have Halibut constantly adapt to make
196the best use of the current encoding.) For example, you might write
197\cw{\\cfg\{text-bullet\}\{\\u2022\}\{\\u00b7\}\{*\}}, in which case
198Halibut would use the Unicode \q{BULLET} character where possible,
199fall back to the ISO-8859-1 \q{MIDDLE DOT} if that wasn't available,
200and resort to the ASCII asterisk if all else failed.
201
202}
203
204\dt \I{\cw{\\cfg\{text-rule\}}}\cw{\\cfg\{text-rule\}\{}\e{text}\cw{\}}[\cw{\{}\e{text}...\cw{\}}]
205
206\dd This specifies the text which should be used for drawing
207\i{horizontal rules} (generated by \i\c{\\rule}; see
208\k{input-rule}). It can be one character, or more than one. The
209string you specify will be repeated to reach the required width, so
210you can specify something like \q{\cw{-=}} to get a rule that looks
211like \cw{-=-=-=}.
212
213\lcont{
214
215Like \cw{\\cfg\{text-bullet\}}, you can specify multiple fallback
216options in this command.
217
218}
219
220\dt \I{\cw{\\cfg\{text-quotes\}}}\cw{\\cfg\{text-quotes\}\{}\e{open-quote}\cw{\}\{}\e{close-quote}\cw{\}}[\cw{\{}\e{open-quote}\cw{\}\{}\e{close-quote}...\cw{\}}]
221
222\dd This specifies the quote characters which should be used in
223response to the \c{\\q} command (see \k{input-quotes}). These quotes
224will also be used to mark text enclosed in the \c{\\c} command (see
225\k{input-code}).
226
227\lcont{
228
229You should separately specify the open and close quote characters,
230each of which can be more than one character if you want. Also, like
231\cw{\\cfg\{text-bullet\}}, you can specify multiple fallback options
232in this command (a pair of open and close quotes, then another pair,
233then another if you like); Halibut will always use a matching pair.
234For example, you might write
235
236\c \cfg{text-quotes}{\u201c}{\u201d}{"}{"}
237
238and Halibut would use the Unicode matched double quote characters if
239possible, and fall back to ASCII double quotes otherwise. If the
240output character set were to contain U+201C but not U+201D, then
241Halibut would fall back to using the ASCII double quote character as
242\e{both} open and close quotes. (No known character set is that
243silly; I mention it only as an example.)
244
245}
246
247\dt \I{\cw{\\cfg\{text-emphasis\}}}\cw{\\cfg\{text-emphasis\}\{}\e{start-emph}\cw{\}\{}\e{end-emph}\cw{\}}[\cw{\{}\e{start-emph}\cw{\}\{}\e{end-emph}...\cw{\}}]
248
249\dd This specifies the text which should be used to surround
250emphasised text (written using the \c{\\e} command; see
251\k{input-emph}).
252
253\lcont{
254
255You should separately specify the start-emphasis and end-emphasis
256text, each of which can be more than one character if you want.
257Also, like \cw{\\cfg\{text-quotes\}}, you can specify multiple pairs
258of fallback options in this command, and Halibut will always use a
259matching pair.
260
261}
262
16ea3abe 263\S{output-text-misc} Miscellaneous configuration options
264
db662ca1 265\dt \I{\cw{\\cfg\{text-list-suffix\}}}\cw{\\cfg\{text-list-suffix\}\{}\e{text}\cw{\}}
266
267\dd This text is appended to the number on a \i{numbered list} item
268(see \k{input-list-number}). So if you want to label your lists as
269\q{1)}, \q{2)} and so on, then you would write
270\cw{\\cfg\{text-list-suffix\}\{)\}}.
271
339cbe09 272\dt \I{\cw{\\cfg\{text-versionid\}}}\cw{\\cfg\{text-versionid\}\{}\e{boolean}\cw{\}}
16ea3abe 273
339cbe09 274\dd If this is set to \c{true}, \i{version ID paragraphs} (defined
275using the \i\c{\\versionid} command - see \k{input-blurb}) will be
276included at the bottom of the text file. If it is set to \c{false},
277they will be omitted completely.
16ea3abe 278
16ea3abe 279\# FIXME: code indentation is configurable, therefore \quote
280\# indentation probably ought to be as well.
281
282\# FIXME: text-indent-* should be consistently named.
283
284\S{output-text-defaults} Default settings
285
339cbe09 286The \i{default settings} for Halibut's plain text output format are:
16ea3abe 287
0a6347b4 288\c \cfg{text-filename}{output.txt}
289\c
16ea3abe 290\c \cfg{text-width}{68}
291\c \cfg{text-indent}{7}
292\c \cfg{text-indent-code}{2}
293\c \cfg{text-list-indent}{1}
294\c \cfg{text-listitem-indent}{3}
295\c \cfg{text-indent-preamble}{false}
296\c
297\c \cfg{text-title-align}{centre}
db662ca1 298\c \cfg{text-title-underline}{\u2550}{=}
16ea3abe 299\c
300\c \cfg{text-chapter-align}{left}
db662ca1 301\c \cfg{text-chapter-underline}{\u203e}{-}
16ea3abe 302\c \cfg{text-chapter-numeric}{false}
303\c \cfg{text-chapter-suffix}{: }
304\c
305\c \cfg{text-section-align}{0}{leftplus}
306\c \cfg{text-section-underline}{0}{}
307\c \cfg{text-section-numeric}{0}{true}
308\c \cfg{text-section-suffix}{0}{ }
309\c
310\c \cfg{text-section-align}{1}{leftplus}
311\c \cfg{text-section-underline}{1}{}
312\c \cfg{text-section-numeric}{1}{true}
313\c \cfg{text-section-suffix}{1}{ }
314\c
315\c ... and so on for all section levels below this ...
316\e iiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiii
db662ca1 317\c
318\c \cfg{text-bullet}{\u2022}{-}
319\c \cfg{text-rule}{\u2500}{-}
320\c \cfg{text-quotes}{\u2018}{\u2019}{`}{'}
321\c \cfg{text-emphasis}{_}{_}
322\c
323\c \cfg{text-list-suffix}{.}
324\c \cfg{text-versionid}{true}
16ea3abe 325
326\H{output-html} HTML
327
339cbe09 328This output format generates an \i{HTML} version of the document. By
16ea3abe 329default, this will be in multiple files, starting with
330\c{Contents.html} and splitting the document into files by chapter
331and/or subsection. You can configure precisely how the text is split
332between HTML files using the configuration commands described in
333this section. In particular, you can configure Halibut to output one
0a6347b4 334single HTML file instead of multiple ones.
16ea3abe 335
339cbe09 336Strictly speaking, the output format is \i{XHTML} 1.0 Transitional,
16ea3abe 337which is why all of the configuration directives start with the word
338\c{xhtml} rather than \c{html}.
339
0a6347b4 340\S{output-html-file} Controlling the output file names
341
342\dt \I{\cw{\\cfg\{xhtml-contents-filename\}}}\cw{\\cfg\{xhtml-contents-filename\}\{}\e{filename}\cw{\}}
343
344\dd Sets the \i{output file name} in which to store the top-level
345contents page. Since this is the first page a user ought to see when
346beginning to read the document, a good choice in many cases might be
fc8e7adb 347\c{index.html} (although this is not the default, for historical
0a6347b4 348reasons).
349
350\dt \I{\cw{\\cfg\{xhtml-index-filename\}}}\cw{\\cfg\{xhtml-index-filename\}\{}\e{filename}\cw{\}}
351
352\dd Sets the file name in which to store the document's index.
353
354\dt \I{\cw{\\cfg\{xhtml-template-filename\}}}\cw{\\cfg\{xhtml-template-filename\}\{}\e{template}\cw{\}}
355
356\dd Provides a \i{template} to be used when constructing the file
357names of each chapter or section of the document. This template
358should contain at least one \i\e{formatting command}, in the form of
359a per cent sign followed by a letter. (If you need a literal per
360cent sign, you can write \c{%%}.)
361
362\lcont{
363
364The formatting commands used in this template are:
365
366\dt \i\c{%N}
367
368\dd Expands to the visible title of the section, with white space
369removed. So in a chapter declared as \q{\cw{\\C\{fish\} Catching
370Fish}}, this formatting command would expand to
371\q{\cw{CatchingFish}}.
372
373\dt \i\c{%n}
374
375\dd Expands to the type and number of the section, without white
376space. So in chapter 1 this would expand to \q{\cw{Chapter1}}; in
377section A.4.3 it would expand to \q{\cw{SectionA.4.3}}, and so on.
378If the section has no number (an unnumbered chapter created using
379\c{\\U}), this directive falls back to doing the same thing as
380\c{%N}.
381
382\dt \i\c{%b}
383
384\dd Expands to the bare number of the section. So in chapter 1 this
385would expand to \q{\cw{1}}; in section A.4.3 it would expand to
386\q{\cw{A.4.3}}, and so on. If the section has no number (an
387unnumbered chapter created using \c{\\U}), this directive falls back
388to doing the same thing as \c{%N}.
389
390\dt \i\c{%k}
391
392\dd Expands to the internal keyword specified in the section title.
393So in a chapter declared as \q{\cw{\\C\{fish\} Catching Fish}}, this
394formatting command would expand to \q{\cw{fish}}. If the section has
395no keyword (an unnumbered chapter created using \c{\\U}), this
396directive falls back to doing the same thing as \c{%N}.
397
398These formatting directives can also be used in the
399\cw{\\cfg\{xhtml-template-fragment\}} configuration directive (see
400\k{output-html-misc}).
401
402}
403
404\dt \I{\cw{\\cfg\{xhtml-single-filename\}}}\cw{\\cfg\{xhtml-single-filename\}\{}\e{filename}\cw{\}}
405
406\dd Sets the file name in which to store the entire document, if
407Halibut is configured (using \c{\\cfg\{xhtml-leaf-level\}\{0\}} to
408produce a single self-contained file. Both this directive \e{and}
409\c{\\cfg\{xhtml-leaf-level\}\{0\}} are implicitly generated if you
410provide a file name parameter after the command-line option
411\i\c{--html} (see \k{running-options}).
412
16ea3abe 413\S{output-html-split} Controlling the splitting into HTML files
414
415By default, the HTML output from Halibut is split into multiple
416files. Each file typically contains a single chapter or section and
417everything below it, unless subsections of that chapter are
418themselves split off into further files.
419
420Most files also contain a contents section, giving hyperlinks to the
421sections in the file and/or the sections below it.
422
423The configuration directives listed below allow you to configure the
424splitting into files, and the details of the contents sections.
425
339cbe09 426\dt \I{\cw{\\cfg\{xhtml-leaf-level\}}}\cw{\\cfg\{xhtml-leaf-level\}\{}\e{depth}\cw{\}}
16ea3abe 427
428\dd This setting indicates the depth of section which should be
339cbe09 429given a \I{leaf file}\q{leaf} file (a file with no sub-files). So if
430you set it to 1, for example, then every chapter will be given its
431own HTML file, plus a top-level \i{contents file}. If you set this
432to 2, then each chapter \e{and} each \c{\\H} section will have a
433file, and the chapter files will mostly just contain links to their
434\i{sub-file}s.
16ea3abe 435
436\lcont{
437
438If you set this option to zero, then the whole document will appear
439in a single file. If you do this, Halibut will call that file
339cbe09 440\i\c{Manual.html} instead of \i\c{Contents.html}.
16ea3abe 441
0a6347b4 442This option is automatically set to zero if you provide a file name
443parameter after the command-line option \i\c{--html} (see
444\k{running-options}), because you have specified a single file name
445and so Halibut assumes you want the whole document to be placed in
446that file.
447
16ea3abe 448}
449
339cbe09 450\dt \I{\cw{\\cfg\{xhtml-contents-depth\}}}\cw{\\cfg\{xhtml-contents-depth-}\e{level}\cw{\}\{}\e{depth}\cw{\}}
16ea3abe 451
339cbe09 452\dd This directive allows you to specify how \I{depth of
453contents}deep the contents section in a particular file should go.
16ea3abe 454
455\lcont{
456
457The \e{level} parameter indicates which level of contents section
458you are dealing with. 0 denotes the main contents section in the
459topmost file \c{Contents.html}; 1 denotes a contents section in a
460chapter file; 2 is a contents section in a file containing a \c{\\H}
461heading, and so on. Currently you can't go below level 5 (which
462corresponds to a \c{\\S3} heading).
463
464The \e{depth} parameter indicates the maximum depth of heading which
465will be shown in this contents section. Again, 1 denotes a chapter,
4662 is a \c{\\H} heading, 3 is a \c{\\S} heading, and so on.
467
468So, for example: \cw{\\cfg\{xhtml-contents-depth-1\}\{3\}} instructs
469Halibut to put contents links in chapter files for all sections down
470to \c{\\S} level, but not to go into any more detail than that.
471
472}
473
474\# FIXME: this is utterly ghastly. For a start, it should include
475\# the level as a separate argument, like the text section config
476\# directives. Secondly, it shouldn't be limited in depth!
477
339cbe09 478\dt \I{\cw{\\cfg\{xhtml-leaf-contains-contents\}}}\cw{\\cfg\{xhtml-leaf-contains-contents\}\{}\e{boolean}\cw{\}}
16ea3abe 479
480\dd If you set this to \c{true}, then each leaf file will contain
481its own contents section which summarises the text within it.
482
339cbe09 483\dt \I{\cw{\\cfg\{xhtml-leaf-smallest-contents\}}}\cw{\\cfg\{xhtml-leaf-smallest-contents\}\{}\e{number}\cw{\}}
16ea3abe 484
485\dd Contents sections in leaf files are not output at all if they
486contain very few entries (on the assumption that it just isn't worth
487bothering). This directive configures the minimum number of entries
488required in a leaf contents section to make Halibut bother
489generating it at all.
490
491\S{output-html-html} Including pieces of your own HTML
492
493The directives in this section allow you to supply pieces of
339cbe09 494\I{HTML}\i{verbatim HTML} code, which will be included in various
495parts of the output files.
16ea3abe 496
339cbe09 497\dt \I{\cw{\\cfg\{xhtml-head-end\}}}\cw{\\cfg\{xhtml-head-end\}\{}\e{HTML text}\cw{\}}
16ea3abe 498
499\dd The text you provide in this directive is placed at the end of
339cbe09 500the \i\cw{<HEAD>} section of each output HTML file. So this is a
501good place to put, for example, a link to a \i{CSS} \i{stylesheet}.
16ea3abe 502
339cbe09 503\dt \I{\cw{\\cfg\{xhtml-body-tag\}}}\cw{\\cfg\{xhtml-body-tag\}\{}\e{HTML text}\cw{\}}
16ea3abe 504
505\dd The text you provide in this directive is used in place of the
339cbe09 506\i\cw{<BODY>} tag in each output file. So if you wanted to define a
507\i{background colour}, for example, you could write
16ea3abe 508\cw{\\cfg\{xhtml-body-tag\}\{<body bg="#123456">\}}.
509
339cbe09 510\dt \I{\cw{\\cfg\{xhtml-body-start\}}}\cw{\\cfg\{xhtml-body-start\}\{}\e{HTML text}\cw{\}}
16ea3abe 511
512\dd The text you provide in this directive is placed at the
339cbe09 513beginning of the \i\cw{<BODY>} section of each output HTML file. So
514if you intend your HTML files to be part of a web site with a
515standard \i{house style}, and the style needs a \i{header} at the
516top of every page, this is where you can add that header.
16ea3abe 517
339cbe09 518\dt \I{\cw{\\cfg\{xhtml-body-end\}}}\cw{\\cfg\{xhtml-body-end\}\{}\e{HTML text}\cw{\}}
16ea3abe 519
339cbe09 520\dd The text you provide in this directive is placed at the end of
521the \i\cw{<BODY>} section of each output HTML file. So if you intend
522your HTML files to be part of a web site with a standard \i{house
523style}, and the style needs a \i{footer} at the bottom of every
524page, this is where you can add that footer.
16ea3abe 525
339cbe09 526\dt \I{\cw{\\cfg\{xhtml-address-start\}}}\cw{\\cfg\{xhtml-address-start\}\{}\e{HTML text}\cw{\}}
16ea3abe 527
528\dd The text you provide in this directive is placed at the
339cbe09 529beginning of the \i\cw{<ADDRESS>} section at the bottom of each
530output HTML file. This might be a good place to put authors'
531\i{contact details}, for example.
16ea3abe 532
339cbe09 533\dt \I{\cw{\\cfg\{xhtml-address-end\}}}\cw{\\cfg\{xhtml-address-end\}\{}\e{HTML text}\cw{\}}
16ea3abe 534
339cbe09 535\dd The text you provide in this directive is placed at the end of
536the \i\cw{<ADDRESS>} section at the bottom of each output HTML file,
537after the version IDs (if present).
16ea3abe 538
339cbe09 539\dt \I{\cw{\\cfg\{xhtml-navigation-attributes\}}}\cw{\\cfg\{xhtml-navigation-attributes\}\{}\e{HTML attributes}\cw{\}}
16ea3abe 540
541\dd The text you provide in this directive is included inside the
339cbe09 542\cw{<P>} tag containing the \i{navigation links} at the top of each
543page (\i{\q{Previous}} / \i{\q{Contents}} / \i{\q{Next}}). So if you
544wanted the navigation links to have a particular CSS style, you
545could write
16ea3abe 546\cw{\\cfg\{xhtml-navigation-attributes\}\{class="foo"\}}, and the
547navigation-links paragraph would then begin with the tag \cw{<p
548class="foo">}.
549
339cbe09 550\S{output-html-headings} \ii{Configuring heading display}
16ea3abe 551
339cbe09 552\dt \I{\cw{\\cfg\{xhtml-chapter-numeric\}}}\cw{\\cfg\{xhtml-chapter-numeric\}\{}\e{boolean}\cw{\}}
16ea3abe 553
554\dd If this is set to \c{true}, then chapter headings will not
555contain the word \q{Chapter} (or whatever other word you have
556defined in its place - see \k{input-sections} and \k{input-config});
557they will just contain the chapter \e{number}, followed by the
558chapter title. If you set this to \c{false}, chapter headings will
559be prefixed by \q{Chapter} or equivalent.
560
339cbe09 561\dt \I{\cw{\\cfg\{xhtml-chapter-suffix\}}}\cw{\\cfg\{xhtml-chapter-suffix\}\{}\e{text}\cw{\}}
16ea3abe 562
563\dd This specifies the suffix text to be appended to the chapter
564number, before displaying the chapter title. For example, if you set
565this to \q{\cw{:\_}}, then the chapter title might look something
566like \q{Chapter 2: Doing Things}.
567
339cbe09 568\dt \I{\cw{\\cfg\{xhtml-section-numeric\}}}\cw{\\cfg\{xhtml-section-numeric\}\{}\e{boolean}\cw{\}}
16ea3abe 569
570\dd Specifies whether section headings at a particular level should
571contain the word \q{Section} or equivalent (if \c{false}), or should
572be numeric only (if \c{true}). The \e{level} parameter specifies
573which level of section headings you want to affect: 0 means
574first-level headings (\c{\\H}), 1 means second-level headings
575(\c{\\S}), 2 means the level below that (\c{\\S2}), and so on.
576
339cbe09 577\dt \I{\cw{\\cfg\{xhtml-section-suffix\}}}\cw{\\cfg\{xhtml-section-suffix\}\{}\e{text}\cw{\}}
16ea3abe 578
579\dd Specifies the suffix text to be appended to section numbers at a
580particular level, before displaying the section title.
581
582\S{output-html-misc} Miscellaneous options
583
0a6347b4 584\dt \I{\cw{\\cfg\{xhtml-template-fragment\}}}\cw{\\cfg\{xhtml-template-fragment\}\{}\e{template}\cw{\}}
585
586\dd This directive lets you specify a \i{template}, with exactly the
587same syntax used in \cw{\\cfg\{xhtml-template-filename\}} (see
fc8e7adb 588\k{output-html-file}), to be used for the anchor names (\i\cw{<A
589NAME="...">}) used to allow URLs to refer to specific sections
590within a particular HTML file. So if you set this to \q{\cw{%k}},
591for example, then each individual section in your document will be
0a6347b4 592addressable by means of a URL ending in a \c{#} followed by your
593internal section keyword.
594
339cbe09 595\dt \I{\cw{\\cfg\{xhtml-versionid\}}}\cw{\\cfg\{xhtml-versionid\}\{}\e{boolean}\cw{\}}
16ea3abe 596
339cbe09 597\dd If this is set to \c{true}, \i{version ID paragraphs} (defined using
598the \i\c{\\versionid} command - see \k{input-blurb}) will be included
599visibly in the \i\cw{<ADDRESS>} section at the bottom of each HTML
16ea3abe 600file. If it is set to \c{false}, they will be omitted completely.
601
602\# FIXME: surely it would be better to include them in HTML
603\# comments? The only question is whether they should be _visible_.
604
339cbe09 605\dt \I{\cw{\\cfg\{xhtml-suppress-address\}}}\cw{\\cfg\{xhtml-suppress-address\}\{}\e{boolean}\cw{\}}
16ea3abe 606
339cbe09 607\dd If this is set to \c{true}, the \i\cw{<ADDRESS>} section at the
16ea3abe 608bottom of each HTML file will be omitted completely. (This will
339cbe09 609therefore also cause \i{version IDs} not to be included.)
16ea3abe 610
339cbe09 611\dt \I{\cw{\\cfg\{xhtml-author\}}}\cw{\\cfg\{xhtml-author\}\{}\e{text}\cw{\}}
16ea3abe 612
339cbe09 613\dd The text supplied here goes in a \I{\cw{<META>} tags}\cw{<META
614name="author">} tag in the output HTML files, so that browsers which
615support this can automatically identify the \i{author} of the document.
16ea3abe 616
339cbe09 617\dt \I{\cw{\\cfg\{xhtml-description\}}}\cw{\\cfg\{xhtml-description\}\{}\e{text}\cw{\}}
16ea3abe 618
339cbe09 619\dd The text supplied here goes in a \I{\cw{<META>} tags}\cw{<META
620name="description">} tag in the output HTML files, so that browsers
621which support this can easily pick out a brief \I{description, of
622document}description of the document.
16ea3abe 623
624\S{output-html-defaults} Default settings
625
339cbe09 626The \i{default settings} for Halibut's HTML output format are:
16ea3abe 627
0a6347b4 628\c \cfg{xhtml-contents-filename}{Contents.html}
629\c \cfg{xhtml-index-filename}{IndexPage.html}
630\c \cfg{xhtml-template-filename}{%n.html}
631\c \cfg{xhtml-single-filename}{Manual.html}
632\c \cfg{xhtml-template-fragment}{%b}
633\c
16ea3abe 634\c \cfg{xhtml-leaf-level}{2}
635\c \cfg{xhtml-leaf-contains-contents}{false}
636\c \cfg{xhtml-leaf-smallest-contents}{4}
637\c \cfg{xhtml-contents-depth-0}{2}
638\c \cfg{xhtml-contents-depth-1}{3}
639\c \cfg{xhtml-contents-depth-2}{4}
640\c \cfg{xhtml-contents-depth-3}{5}
641\c \cfg{xhtml-contents-depth-4}{6}
642\c \cfg{xhtml-contents-depth-5}{7}
643\c
644\c \cfg{xhtml-head-end}{}
645\c \cfg{xhtml-body-tag}{<body>}
646\c \cfg{xhtml-body-start}{}
647\c \cfg{xhtml-body-end}{}
648\c \cfg{xhtml-address-start}{}
649\c \cfg{xhtml-address-end}{}
650\c \cfg{xhtml-navigation-attributes}{}
651\c
652\c \cfg{xhtml-versionid}{true}
653\c \cfg{xhtml-suppress-address}{false}
654\c \cfg{xhtml-author}{}
655\c \cfg{xhtml-description}{}
656\c
657\c \cfg{xhtml-chapter-numeric}{false}
658\c \cfg{xhtml-chapter-suffix}{: }
659\c
660\c \cfg{xhtml-section-numeric}{0}{true}
661\c \cfg{xhtml-section-suffix}{0}{ }
662\c
663\c \cfg{xhtml-section-numeric}{1}{true}
664\c \cfg{xhtml-section-suffix}{1}{ }
665\c
666\c ... and so on for all section levels below this ...
667\e iiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiii
668
669\H{output-whlp} Windows Help
670
339cbe09 671This output format generates data that can be used by the \i{Windows
0a6347b4 672Help} program \cw{WINHELP.EXE}. There are two actual files
673generated, one ending in \c{.hlp} and the other ending in \c{.cnt}.
674
675The Windows Help output format supports the following configuration
676directives:
677
678\dt \I{\cw{\\cfg\{winhelp-filename\}}}\cw{\\cfg\{winhelp-filename\}\{}\e{filename}\cw{\}}
679
680\dd Sets the \i{output file name} in which to store the man page.
681This directive is implicitly generated if you provide a file name
682parameter after the command-line option \i\c{--winhelp} (see
683\k{running-options}).
684
685\lcont{
686
687Your output file name should end with \c{.hlp}; if it doesn't,
688Halibut will append it. Halibut will also generate a contents file
689(ending in \c{.cnt}) alongside the file name you specify.
690
691}
16ea3abe 692
339cbe09 693\dt \I{\cw{\\cfg\{winhelp-topic\}}}\cw{\\cfg\{winhelp-topic\}\{}\e{topic-name}\cw{\}}
16ea3abe 694
339cbe09 695\dd This directive defines a Windows \i{Help topic} name in the current
16ea3abe 696section. Topic names can be used by the program invoking
697\cw{WINHELP.EXE} to jump straight to a particular section. So you
339cbe09 698can use this for \i{context-sensitive help}.
16ea3abe 699
700\lcont{
701
702For example, if you used this directive in a particular section:
703
704\c \cfg{winhelp-topic}{savingfiles}
705
706then a Windows application could invoke Windows Help to jump to that
707particular section in the help file like this:
708
709\c WinHelp(hwnd, "mydoc.hlp", HELP_COMMAND,
710\c (DWORD)"JI(`',`savingfiles')");
711
712You can use this configuration directive many times, in many
713different subsections of your document, in order to define a lot of
714different help contexts which you can use in this way.
715
716}
717
0a6347b4 718The \i{default settings} for the Windows Help output format are:
719
720\c \cfg{winhelp-filename}{output.hlp}
721
722and no \c{\\cfg\{winhelp-topic\}} directives anywhere.
723
16ea3abe 724\H{output-man} Unix \cw{man} pages
725
339cbe09 726This output format generates a Unix \i{\cw{man} page}. That is to say,
727it generates \i\c{nroff} input designed to work with the \c{-mandoc}
16ea3abe 728macro package.
729
730The available configuration options for this format are as follows:
731
0a6347b4 732\dt \I{\cw{\\cfg\{man-filename\}}}\cw{\\cfg\{man-filename\}\{}\e{filename}\cw{\}}
733
734\dd Sets the \i{output file name} in which to store the man page.
735This directive is implicitly generated if you provide a file name
736parameter after the command-line option \i\c{--man} (see
737\k{running-options}).
738
339cbe09 739\dt \I{\cw{\\cfg\{man-identity\}}}\cw{\\cfg\{man-identity\}\{}\e{text}\cw{\}\{}\e{text...}\cw{\}}
16ea3abe 740
339cbe09 741\dd This directive is used to generate the initial \i{\c{.TH}
742directive} that appears at the top of a \cw{man} page. It expects to
743be followed by some number of brace pairs containing text, which will
744be used in the \i{headers} and \i{footers} of the formatted output.
16ea3abe 745
746\lcont{
747
748A traditional order for the arguments appears to be:
749
750\n The name of the program.
751
752\n The (numeric) manual section.
753
754\n The date that the \cw{man} page was written.
755
756\n The name of any containing suite of which the program is a part.
757
339cbe09 758\n The name of the \i{author} of the \cw{man} page.
16ea3abe 759
760For example, a typical \cw{man} page might contain
761
fc8e7adb 762\c \cfg{man-identity}{make-foo}{1}{June 2003}{foo-utils}{Fred
763\c Bloggs}
16ea3abe 764
765}
766
339cbe09 767\dt \I{\cw{\\cfg\{man-headnumbers\}}}\cw{\\cfg\{man-headnumbers\}\{}\e{boolean}\cw{\}}
16ea3abe 768
339cbe09 769\dd If this is set to \c{true}, then \i{section headings} in the
770\cw{man} page will have their \i{section numbers} displayed as usual. If
16ea3abe 771set to \c{false}, the section numbers will be omitted. (\cw{man}
772pages traditionally have section names such as \q{SYNOPSIS},
773\q{OPTIONS} and \q{BUGS}, and do not typically number them, so
774\c{false} is the setting which conforms most closely to normal
775\cw{man} style.)
776
339cbe09 777\dt \I{\cw{\\cfg\{man-mindepth\}}}\cw{\\cfg\{man-mindepth\}\{}\e{depth}\cw{\}}
16ea3abe 778
779\dd If this is set to a number greater than 0, then section headings
780\e{higher} than the given depth will not be displayed. If it is set
781to zero, all section headings will be displayed as normal.
782
783\lcont{
784
785The point of this is so that you can use the same Halibut input file
786to generate a quick-reference \cw{man} page for a program, \e{and} to
787include that \cw{man} page as an appendix in your program's full manual.
788If you are to include the \cw{man} page as an appendix, then the internal
789headings within the page will probably need to be at \c{\\H} or
790\c{\\S} level; therefore, when you format that input file on its own
791to create the \cw{man} page itself, you will need to have defined a
792\c{\\C} and possibly a \c{\\H} heading beforehand, which you don't
793want to see displayed.
794
795Here's an example. You might have a file \c{appendix.but}, which
796simply says
797
798\c \A{manpages} \cw{man} pages for the Foo tool suite
799\c
800\c \cfg{man-mindepth}{2}
801
802Then you have a file \c{make-foo.but}, and probably others like it
803as well, each of which looks something like this:
804
fc8e7adb 805\c \cfg{man-identity}{make-foo}{1}{June 2003}{foo-utils}{Fred
806\c Bloggs}
16ea3abe 807\c
808\c \H{man-foo} \cw{man} page for \c{make-foo}
809\c
810\c \S{man-foo-name} NAME
811\c
812\c \c{make-foo} - create Foo files for the Foo tool suite
813\c
814\c \S{man-foo-synopsis} SYNOPSIS
815\c
816\c ... and so on ...
817\e iiiiiiiiiiiiiiiii
818
819So when you're generating your main manual, you can include
820\c{appendix.but} followed by \c{make-foo.but} and any other \cw{man}
821pages you have, and your \cw{man} pages will be formatted neatly as
822part of an appendix. Then, in a separate run of Halibut, you can
823just do
824
825\c halibut appendix.but make-foo.but
826
827and this will generate a \cw{man} page \c{output.1}, in which the
828headings \q{\cw{man} pages for the Foo tool suite} and \q{\cw{man}
829page for \c{make-foo}} will not be displayed because of the
830\c{man-mindepth} directive. So the first visible heading in the
831output \cw{man} page will be \q{NAME}, exactly as a user would
832expect.
833
834}
835
339cbe09 836The \i{default settings} for the \cw{man} page output format are:
16ea3abe 837
0a6347b4 838\c \cfg{man-filename}{output.1}
16ea3abe 839\c \cfg{man-identity}{}
840\c \cfg{man-headnumbers}{false}
841\c \cfg{man-mindepth}{0}
43f61c25 842
843\H{output-info} GNU \c{info}
844
845This output format generates files which can be used with the \i{GNU
846\c{info}} program.
847
848There are typically multiple output files: a primary file whose name
849usually ends in \c{.info}, and one or more subsidiary files whose
850names have numbers on the end, so that they end in \c{.info-1},
851\c{.info-2} and so on. Alternatively, this output format can be
852configured to output a single large file containing the whole
853document.
854
855The \c{info} output format supports the following configuration
856directives:
857
858\dt \I{\cw{\\cfg\{info-filename\}}}\cw{\\cfg\{info-filename\}\{}\e{filename}\cw{\}}
859
860\dd Sets the output file name in which to store the \c{info} file.
861This directive is implicitly generated if you provide a file name
862parameter after the command-line option \i\c{--info} (see
863\k{running-options}).
864
865\lcont{
866
867The suffixes \c{-1}, \c{-2}, \c{-3} and so on will be appended to
868your output file name to produce any subsidiary files required.
869
870Note that \c{info} files refer to their own names internally, so
871these files cannot be \I{renaming \c{info} files}renamed after
872creation and remain useful.
873
874}
875
876\dt \I{\cw{\\cfg\{info-max-file-size\}}}\cw{\\cfg\{info-max-file-size\}\{}\e{bytes}\cw{\}}
877
878\dd Sets the preferred \i{maximum file size} for each subsidiary
879file. As a special case, if you set this to zero, there will be no
880subsidiary files and the whole document will be placed in a single
881self-contained output file. (However, note that this file can still
882not be renamed usefully.)
883
884\lcont{
885
886The preferred maximum file size is only a guideline. Halibut may be
887forced to exceed it if a single section of the document is larger
888than the maximum size (since individual \c{info} nodes may not be
889split between files).
890
891}
892
893\dt \I{\cw{\\cfg\{info-dir-entry\}}}\cw{\\cfg\{info-dir-entry\}\{}\e{section}\cw{\}\{}\e{short
894name}\cw{\}\{}\e{long name}\cw{\}}[\cw{\{}\e{keyword}\cw{\}}]
895
896\dd Constructs an \i\cw{INFO-DIR-ENTRY} section and places it in the
897header of the Info file. This mechanism is used to automatically
898generate the \i{\c{dir} file} at the root of a Unix system's
899\c{info} collection.
900
901\lcont{
902
903The parameters to this directive are:
904
905\dt \e{section}
906
907\dd Specifies the section of the \c{dir} file in which you want your
908document referenced. For example, \q{Development}, or \q{Games}, or
909\q{Miscellaneous}.
910
911\dt \e{short name}
912
913\dd Specifies a short name for the directory entry, which will
914appear at the start of the menu line.
915
916\dt \e{long name}
917
918\dd Specifies a long name for the directory entry, which will appear
919at the end of the menu line.
920
921\dt \e{keyword}
922
923\dd This parameter is optional. If it is present, then the directory
924entry will cause a jump to a particular subsection of your document,
925rather than starting at the top. The subsection will be the one
926referred to by the given keyword (see \k{input-sections} for details
927about assigning keywords to document sections).
928
929For example, in a document describing many game programs, the
930configuration directive
931
fc8e7adb 932\c \cfg{info-dir-entry}{Games}{Chess}{Electronic chess
933\c game}{chess}
43f61c25 934
935might produce text in the \c{dir} file looking something like this:
936
937\c Games
938\c * Chess: (mygames)Chapter 3. Electronic chess game
939
940if the output file were called \c{mygames.info} and the keyword
941\c{chess} had been used to define Chapter 3 of the document.
942
943}
0287083a 944
945\H{output-ps} \i{PostScript}
946
947This output format generates a printable manual in PostScript format.
948
949This format is currently very new and is not yet configurable. There
950is only one available configuration option:
951
952\dt \I{\cw{\\cfg\{ps-filename\}}}\cw{\\cfg\{ps-filename\}\{}\e{filename}\cw{\}}
953
954\dd Sets the \i{output file name} in which to store the PostScript
955file. This directive is implicitly generated if you provide a file
956name parameter after the command-line option \i\c{--ps} (see
957\k{running-options}).
958
959The \i{default settings} for the PostScript output format are:
960
961\c \cfg{ps-filename}{output.ps}
962
963\H{output-pdf} \i{PDF}
964
965This output format generates a printable manual in PDF format. This
966should look exactly identical to the PostScript output (see
967\k{output-ps}), but also uses some PDF interactive features to
968provide an outline of all the document's sections and clickable
969cross-references between sections.
970
971This format is currently very new and is not yet configurable. There
972is only one available configuration option:
973
974\dt \I{\cw{\\cfg\{pdf-filename\}}}\cw{\\cfg\{pdf-filename\}\{}\e{filename}\cw{\}}
975
976\dd Sets the \i{output file name} in which to store the PDF file.
977This directive is implicitly generated if you provide a file name
978parameter after the command-line option \i\c{--pdf} (see
979\k{running-options}).
980
981The \i{default settings} for the PDF output format are:
982
983\c \cfg{pdf-filename}{output.pdf}