1 .\" $Id: mandoc.db.5,v 1.5 2016/08/01 12:27:15 schwarze Exp $
3 .\" Copyright (c) 2014, 2016 Ingo Schwarze <schwarze@openbsd.org>
5 .\" Permission to use, copy, modify, and distribute this software for any
6 .\" purpose with or without fee is hereby granted, provided that the above
7 .\" copyright notice and this permission notice appear in all copies.
9 .\" THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10 .\" WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11 .\" MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12 .\" ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13 .\" WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14 .\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15 .\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17 .Dd $Mdocdate: August 1 2016 $
22 .Nd manual page database
26 file format is used to store information about installed manual
27 pages to facilitate semantic searching for manuals.
28 Each manual page tree contains its own
34 Such database files are generated by
42 The file format uses three datatypes:
44 .Bl -dash -compact -offset 2n -width 1n
46 32-bit signed integer numbers in big endian (network) byte ordering
48 NUL-terminated strings
50 lists of NUL-terminated strings, terminated by a second NUL character
53 Numbers are aligned to four-byte boundaries; where they follow
54 strings or lists of strings, padding with additional NUL characters
56 Some, but not all, numbers point to positions in the file.
57 These pointers are measured in bytes, and the first byte of the
58 file is considered to be byte 0.
60 Each file consists of:
62 .Bl -dash -compact -offset 2n -width 1n
64 One magic number, 0x3a7d0cdb.
66 One version number, currently 1.
68 One pointer to the macros table.
70 One pointer to the final magic number.
72 The pages table (variable length).
74 The macros table (variable length).
76 The magic number once again, 0x3a7d0cdb.
79 The pages table contains one entry for each physical manual page
80 file, no matter how many hard and soft links it may have in the
82 The pages table consists of:
84 .Bl -dash -compact -offset 2n -width 1n
86 The number of pages in the database.
89 .Bl -dash -compact -offset 2n -width 1n
91 One pointer to the list of names.
93 One pointer to the list of sections.
95 One pointer to the list of architectures
96 or 0 if the page is machine-independent.
98 One pointer to the one-line description string.
100 One pointer to the list of filenames.
103 For each page, the list of names.
104 Each name is preceded by a single byte indicating the sources of the name.
105 The meaning of the bits is:
106 .Bl -dash -compact -offset 2n -width 1n
108 0x10: The name appears in a filename.
110 0x08: The name appears in a header line, i.e. in a .Dt or .TH macro.
112 0x04: The name is the first one in the title line, i.e. it appears
113 in the first .Nm macro in the NAME section.
115 0x02: The name appears in any .Nm macro in the NAME section.
117 0x01: The name appears in an .Nm block in the SYNOPSIS section.
120 For each page, the list of sections.
121 Each section is given as a string, not as a number.
123 For each architecture-dependent page, the list of architectures.
125 For each page, the one-line description string taken from the .Nd macro.
127 For each page, the list of filenames relative to the root of the
129 This list includes hard links, soft links, and links simulated
133 The first filename is preceded by a single byte
134 having the following significance:
135 .Bl -dash -compact -offset 2n -width 1n
137 .Dv FORM_SRC No = 0x01 :
143 .Dv FORM_CAT No = 0x02 :
144 The manual page is preformatted.
147 Zero to three NUL bytes for padding.
150 The macros table consists of:
152 .Bl -dash -compact -offset 2n -width 1n
154 The number of different macro keys, currently 36.
155 The ordering of macros is defined in
157 and the significance of the macro keys is documented in
160 For each macro key, one pointer to the respective macro table.
162 For each macro key, the macro table (variable length).
165 Each macro table consists of:
167 .Bl -dash -compact -offset 2n -width 1n
169 The number of entries in the table.
172 .Bl -dash -compact -offset 2n -width 1n
174 One pointer to the value of the macro key.
175 Each value is a string of text taken from some macro invocation.
177 One pointer to the list of pages.
180 For each entry, the value of the macro key.
182 Zero to three NUL bytes for padding.
184 For each entry, one or more pointers to pages in the pages table,
185 pointing to the pointer to the list of names,
186 followed by the number 0.
189 .Bl -tag -width /usr/share/man/mandoc.db -compact
190 .It Pa /usr/share/man/mandoc.db
191 The manual page database for the base system.
192 .It Pa /usr/X11R6/man/mandoc.db
196 .It Pa /usr/local/man/mandoc.db
203 files in a human-readable format suitable for
205 is provided in the directory
206 .Pa /usr/src/regress/usr.bin/mandoc/db/dbm_dump/ .
213 A manual page database
217 The present format first appeared in
221 The original version of
226 The present database format was designed by
227 .An Ingo Schwarze Aq Mt schwarze@openbsd.org