xref: /dragonfly/contrib/mdocml/makewhatis.8 (revision 0ca59c34)
1.\"	$Id: makewhatis.8,v 1.2 2014/04/25 12:13:15 schwarze Exp $
2.\"
3.\" Copyright (c) 2011, 2012 Kristaps Dzonsons <kristaps@bsd.lv>
4.\" Copyright (c) 2011, 2012 Ingo Schwarze <schwarze@openbsd.org>
5.\"
6.\" Permission to use, copy, modify, and distribute this software for any
7.\" purpose with or without fee is hereby granted, provided that the above
8.\" copyright notice and this permission notice appear in all copies.
9.\"
10.\" THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11.\" WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12.\" MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13.\" ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14.\" WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15.\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16.\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17.\"
18.Dd $Mdocdate: April 25 2014 $
19.Dt MAKEWHATIS 8
20.Os
21.Sh NAME
22.Nm makewhatis
23.Nd index UNIX manuals
24.Sh SYNOPSIS
25.Nm
26.Op Fl aDnpQ
27.Op Fl T Cm utf8
28.Op Fl C Ar file
29.Nm
30.Op Fl aDnpQ
31.Op Fl T Cm utf8
32.Ar dir ...
33.Nm
34.Op Fl DnpQ
35.Op Fl T Cm utf8
36.Fl d Ar dir
37.Op Ar
38.Nm
39.Op Fl Dnp
40.Op Fl T Cm utf8
41.Fl u Ar dir
42.Op Ar
43.Nm
44.Op Fl DQ
45.Fl t Ar
46.Sh DESCRIPTION
47The
48.Nm
49utility extracts keywords from
50.Ux
51manuals and indexes them in a database for fast retrieval by
52.Xr apropos 1 ,
53.Xr whatis 1 ,
54and
55.Xr man 1 Ns 's
56.Fl k
57option.
58.Pp
59By default,
60.Nm
61creates a database in each
62.Ar dir
63using the files
64.Sm off
65.Sy man Ar section Li /
66.Op Ar arch Li /
67.Ar title . section
68.Sm on
69and
70.Sm off
71.Sy cat Ar section Li /
72.Op Ar arch Li /
73.Ar title . Sy 0
74.Sm on
75in that directory.
76Existing databases are replaced.
77If
78.Ar dir
79is not provided,
80.Nm
81uses the default paths stipulated by
82.Xr manpath 1 ,
83or
84.Xr man.conf 5 .
85.Pp
86The arguments are as follows:
87.Bl -tag -width "-C file"
88.It Fl a
89Use all directories and files found below
90.Ar dir ... .
91.It Fl C Ar file
92Specify an alternative configuration
93.Ar file
94in
95.Xr man.conf 5
96format.
97.It Fl D
98Display all files added or removed to the index.
99With a second
100.Fl D ,
101also show all keyswords added for each file.
102.It Fl d Ar dir
103Merge (remove and re-add)
104.Ar
105to the database in
106.Ar dir .
107.It Fl n
108Do not create or modify any database; scan and parse only,
109and print manual page names and descriptions to standard output.
110.It Fl p
111Print warnings about potential problems with manual pages
112to the standard error output.
113.It Fl Q
114Quickly build reduced-size databases
115by reading only the NAME sections of manuals.
116The resulting databases will usually contain names and descriptions only.
117.It Fl T Cm utf8
118Use UTF-8 encoding instead of ASCII for strings stored in the databases.
119.It Fl t Ar
120Check the given
121.Ar files
122for potential problems.
123Implies
124.Fl a ,
125.Fl n ,
126and
127.Fl p .
128All diagnostic messages are printed to the standard output;
129the standard error output is not used.
130.It Fl u Ar dir
131Remove
132.Ar
133from the database in
134.Ar dir .
135.El
136.Pp
137If fatal parse errors are encountered while parsing, the offending file
138is printed to stderr, omitted from the index, and the parse continues
139with the next input file.
140.Sh FILES
141.Bl -tag -width Ds
142.It Pa mandoc.db
143A database of manpages relative to the directory of the file.
144This file is portable across architectures and systems, so long as the
145manpage hierarchy it indexes does not change.
146.It Pa /etc/man.conf
147The default
148.Xr man 1
149configuration file.
150.El
151.Sh EXIT STATUS
152The
153.Nm
154utility exits with one of the following values:
155.Pp
156.Bl -tag -width Ds -compact
157.It 0
158No errors occurred.
159.It 5
160Invalid command line arguments were specified.
161No input files have been read.
162.It 6
163An operating system error occurred, for example memory exhaustion or an
164error accessing input files.
165Such errors cause
166.Nm
167to exit at once, possibly in the middle of parsing or formatting a file.
168The output databases are corrupt and should be removed.
169.El
170.Sh SEE ALSO
171.Xr apropos 1 ,
172.Xr man 1 ,
173.Xr whatis 1 ,
174.Xr man.conf 5
175.Sh HISTORY
176A
177.Nm
178utility first appeared in
179.Bx 2 .
180It was rewritten in
181.Xr perl 1
182for
183.Ox 2.7
184and in C for
185.Ox 5.6 .
186.Pp
187The
188.Ar dir
189argument first appeared in
190.Nx 1.0 ;
191the options
192.Fl dpt
193in
194.Ox 2.7 ;
195the option
196.Fl u
197in
198.Ox 3.4 ;
199and the options
200.Fl aCDnQT
201in
202.Ox 5.6 .
203.Sh AUTHORS
204.An -nosplit
205.An Bill Joy
206wrote the original
207.Bx
208.Nm
209in February 1979,
210.An Marc Espie
211started the Perl version in 2000,
212and the current version of
213.Nm
214was written by
215.An Kristaps Dzonsons Aq Mt kristaps@bsd.lv
216and
217.An Ingo Schwarze Aq Mt schwarze@openbsd.org .
218