test: Move test_data_file() to test.h
[dpkg.git] / man / dpkg-query.pod
blobeaa152488e595aa1b87a64db4b6b33af390559fb
1 # dpkg manual page - dpkg-query(1)
3 # Copyright © 2001 Wichert Akkerman <wakkerma@debian.org>
4 # Copyright © 2006-2007 Frank Lichtenheld <djpig@debian.org>
5 # Copyright © 2006-2015 Guillem Jover <guillem@debian.org>
6 # Copyright © 2008-2011 Raphaël Hertzog <hertzog@debian.org>
8 # This is free software; you can redistribute it and/or modify
9 # it under the terms of the GNU General Public License as published by
10 # the Free Software Foundation; either version 2 of the License, or
11 # (at your option) any later version.
13 # This is distributed in the hope that it will be useful,
14 # but WITHOUT ANY WARRANTY; without even the implied warranty of
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16 # GNU General Public License for more details.
18 # You should have received a copy of the GNU General Public License
19 # along with this program.  If not, see <https://www.gnu.org/licenses/>.
21 =encoding utf8
23 =head1 NAME
25 dpkg-query - a tool to query the dpkg database
27 =head1 SYNOPSIS
29 B<dpkg-query>
30 [I<option>...] I<command>
32 =head1 DESCRIPTION
34 B<dpkg-query> is a tool to show information about packages listed in
35 the B<dpkg> database.
37 =head1 COMMANDS
39 =over
41 =item B<-l>, B<--list> [I<package-name-pattern>...]
43 List all known packages matching one or more patterns, regardless of their
44 status, which includes any real or virtual package referenced in any
45 dependency relationship field (such as B<Breaks>, B<Enhances>, etc.).
46 If no I<package-name-pattern> is given, list all packages in
47 I<%ADMINDIR%/status>, excluding the ones marked as not-installed (i.e.
48 those which have been previously purged).
49 Normal shell wildcard characters are allowed in I<package-name-pattern>.
50 Please note you will probably have to quote I<package-name-pattern> to
51 prevent the shell from performing filename expansion.
52 For example this will list all package names starting with “libc6”:
54 =over
56  dpkg-query -l 'libc6*'
58 =back
60 The first three columns of the output show the desired action, the package
61 status, and errors, in that order.
63 Desired action:
65 =over
67 =item u = Unknown
69 =item i = Install
71 =item h = Hold
73 =item r = Remove
75 =item p = Purge
77 =back
79 Package status:
81 =over
83 =item n = Not-installed
85 =item c = Config-files
87 =item H = Half-installed
89 =item U = Unpacked
91 =item F = Half-configured
93 =item W = Triggers-awaiting
95 =item t = Triggers-pending
97 =item i = Installed
99 =back
101 Error flags:
103 =over
105 =item E<lt>emptyE<gt> = (none)
107 =item R = Reinst-required
109 =back
111 An uppercase status or error letter indicates the package is likely to
112 cause severe problems. Please refer to B<dpkg>(1) for information
113 about the above states and flags.
115 The output format of this option is not configurable, but varies
116 automatically to fit the terminal width. It is intended for human
117 readers, and is not easily machine-readable. See B<-W> (B<--show>)
118 and B<--showformat> for a way to configure the output format.
120 =item B<-W>, B<--show> [I<package-name-pattern>...]
122 Just like the B<--list> option this will list all packages matching
123 the given patterns. However the output can be customized using the
124 B<--showformat> option.
126 The default output format gives one line per matching package,
127 each line consisting of the package name and its installed version,
128 separated by a tab.
129 The package name will be architecture qualified for packages with a
130 B<Multi-Arch> field with the value B<same> or with a foreign architecture,
131 which is an architecture that is neither the native one nor B<all>.
133 =item B<-s>, B<--status> [I<package-name>...]
135 Report status of specified packages. This just displays the entry in
136 the installed package status database.
137 If no I<package-name> is specified it will display all package entries
138 in the status database (since dpkg 1.19.1).
139 When multiple I<package-name> entries are listed, the requested status
140 entries are separated by an empty line, with the same order as specified
141 on the argument list.
143 =item B<-L>, B<--listfiles> I<package-name>...
145 List files installed to your system from I<package-name>. When multiple
146 I<package-name>s are listed, the requested lists of files are separated
147 by an empty line, with the same order as specified on the argument list.
149 Each file diversion is printed on its own line after its diverted file,
150 prefixed with one of the following localized strings:
153   locally diverted to: I<diverted-to>
154   package diverts others to: I<diverted-to>
155   diverted by I<pkg> to: I<diverted-to>
157 B<Hint>: When machine parsing the output, it is customary to set the locale to
158 B<C.UTF-8> to get reproducible results. On some systems this might also
159 require adapting the B<LANGUAGE> environment variable appropriately if it
160 is already set (see L<locale(7)>).
162 This command will not list extra files created by maintainer scripts,
163 nor will it list alternatives.
165 =item B<--control-list> I<package-name>
167 List control files installed to your system from I<package-name>
168 (since dpkg 1.16.5).
169 These can be used as input arguments to B<--control-show>.
171 =item B<--control-show> I<package-name> I<control-file>
173 Print the I<control-file> installed to your system from I<package-name>
174 to the standard output (since dpkg 1.16.5).
176 =item B<-c>, B<--control-path> I<package-name> [I<control-file>]
178 List paths for control files installed to your system from I<package-name>
179 (since dpkg 1.15.4).
180 If I<control-file> is specified then only list the path for that control
181 file if it is present.
183 B<Warning>: this command is deprecated as it gives direct access to the
184 internal dpkg database, please switch to use B<--control-list> and
185 B<--control-show> instead for all cases where those commands might
186 give the same end result. Although, as long as there is still at least
187 one case where this command is needed (i.e. when having to remove a
188 damaging postrm maintainer script), and while there is no good solution
189 for that, this command will not get removed.
191 =item B<-S>, B<--search> I<filename-search-pattern>...
193 Search for packages that own files corresponding to the given patterns.
194 Standard shell wildcard characters can be used in the pattern, where
195 asterisk (B<*>) and question mark (B<?>) will match a slash,
196 and backslash (B<\>) will be used as an escape character.
198 If the first character in the I<filename-search-pattern> is none of
199 ‘B<*[?/>’ then it will be considered a substring match and will be
200 implicitly surrounded by ‘B<*>’ (as in
201 B<*>I<filename-search-pattern>B<*>).
202 If the subsequent string contains any of ‘B<*[?\>’, then it will
203 handled like a glob pattern, otherwise any trailing ‘B</>’ or
204 ‘B</.>’ will be removed and a literal path lookup will be performed.
206 This command will not list extra files created by maintainer scripts,
207 nor will it list alternatives.
209 The output format consists of one line per matching pattern, with a list
210 of packages owning the pathname separated by a comma (U+002C ‘B<,>’) and
211 a space (U+0020 ‘B< >’), followed by a colon (U+003A ‘B<:>’) and a space,
212 followed by the pathname. As in:
214   pkgname1, pkgname2: pathname1
215   pkgname3: pathname2
217 File diversions are printed with the following localized strings:
220   diversion by I<pkgname> from: I<diverted-from>
221   diversion by I<pkgname> to: I<diverted-to>
223 or for local diversions:
226   local diversion from: I<diverted-from>
227   local diversion to: I<diverted-to>
229 B<Hint>: When machine parsing the output, it is customary to set the locale to
230 B<C.UTF-8> to get reproducible results.
232 =item B<-p>, B<--print-avail> [I<package-name>...]
234 Display details about packages, as found in I<%ADMINDIR%/available>.
235 If no I<package-name> is specified, it will display all package entries
236 in the I<available> database (since dpkg 1.19.1).
237 When multiple I<package-name> are listed, the requested I<available>
238 entries are separated by an empty line, with the same order as specified
239 on the argument list.
241 Users of APT-based frontends
242 should use B<apt show> I<package-name> instead
243 as the I<available> file is only kept up-to-date when
244 using B<dselect>.
246 =item B<-?>, B<--help>
248 Show the usage message and exit.
250 =item B<--version>
252 Show the version and exit.
254 =back
256 =head1 OPTIONS
258 =over
260 =item B<--admindir=>I<dir>
262 Change the location of the B<dpkg> database. The default location is
263 I<%ADMINDIR%>.
265 =item B<--root=>I<directory>
267 Set the root directory to I<directory>, which sets the administrative
268 directory to «I<directory>%ADMINDIR%» (since dpkg 1.21.0).
270 =item B<--load-avail>
272 Also load the available file when using the B<--show> and B<--list>
273 commands, which now default to only querying the status file
274 (since dpkg 1.16.2).
276 =item B<--no-pager>
278 Disables the use of any pager when showing information (since dpkg 1.19.2).
280 =item B<-f>, B<--showformat=>I<format>
282 This option is used to specify the format of the output B<--show>
283 will produce (short option since dpkg 1.13.1).
284 The format is a string that will be output for each package listed.
286 In the format string, “B<\>” introduces escapes:
288 =over
290 =item B<\n> newline
292 =item B<\r> carriage return
294 =item B<\t> tab
296 =back
298 “B<\>” before any other character suppresses any special
299 meaning of the following character, which is useful for “B<\>”
300 and “B<$>”.
302 Package information can be included by inserting
303 variable references to package fields using the syntax
304 “B<${>I<field>[B<;>I<width>]B<}>”. Fields are
305 printed right-aligned unless the width is negative in which case left
306 alignment will be used. The following I<field>s are recognized but
307 they are not necessarily available in the status file (only internal
308 fields or fields stored in the binary package end up in it):
310 =over
312 =item B<Architecture>
314 =item B<Bugs>
316 =item B<Conffiles> (internal)
318 =item B<Config-Version> (internal)
320 =item B<Conflicts>
322 =item B<Breaks>
324 =item B<Depends>
326 =item B<Description>
328 =item B<Enhances>
330 =item B<Protected>
332 =item B<Essential>
334 =item B<Filename> (internal, front-end related)
336 =item B<Homepage>
338 =item B<Installed-Size>
340 =item B<MD5sum> (internal, front-end related)
342 =item B<MSDOS-Filename> (internal, front-end related)
344 =item B<Maintainer>
346 =item B<Origin>
348 =item B<Package>
350 =item B<Pre-Depends>
352 =item B<Priority>
354 =item B<Provides>
356 =item B<Recommends>
358 =item B<Replaces>
360 =item B<Revision> (obsolete)
362 =item B<Section>
364 =item B<Size> (internal, front-end related)
366 =item B<Source>
368 =item B<Status> (internal)
370 =item B<Suggests>
372 =item B<Tag> (usually not in .deb but in repository Packages files)
374 =item B<Triggers-Awaited> (internal)
376 =item B<Triggers-Pending> (internal)
378 =item B<Version>
380 =back
382 The following are virtual fields, generated by B<dpkg-query> from
383 values from other fields (note that these do not use valid names for
384 fields in control files):
386 =over
388 =item B<binary:Package>
390 It contains the binary package name with a possible architecture qualifier
391 like “libc6:amd64” (since dpkg 1.16.2).
392 An architecture qualifier will be present to make the package name unambiguous,
393 for packages with a B<Multi-Arch> field with the value B<same> or
394 with a foreign architecture, which is an architecture that is neither
395 the native one nor B<all>.
397 =item B<binary:Synopsis>
399 It contains the package short description (since dpkg 1.19.1).
401 =item B<binary:Summary>
403 This is an alias for B<binary:Synopsis> (since dpkg 1.16.2).
405 =item B<db:Status-Abbrev>
407 It contains the abbreviated package status (as three characters),
408 such as “ii ” or “iHR” (since dpkg 1.16.2).
409 See the B<--list> command description for more details.
411 =item B<db:Status-Want>
413 It contains the package wanted status, part of the Status field
414 (since dpkg 1.17.11).
416 =item B<db:Status-Status>
418 It contains the package status word, part of the Status field
419 (since dpkg 1.17.11).
421 =item B<db:Status-Eflag>
423 It contains the package status error flag, part of the Status field
424 (since dpkg 1.17.11).
426 =item B<db-fsys:Files>
428 It contains the list of the package filesystem entries separated by newlines
429 (since dpkg 1.19.3).
431 =item B<db-fsys:Last-Modified>
433 It contains the timestamp in seconds of the last time the package filesystem
434 entries were modified (since dpkg 1.19.3).
436 =item B<source:Package>
438 It contains the source package name for this binary package
439 (since dpkg 1.16.2).
441 =item B<source:Version>
443 It contains the source package version for this binary package
444 (since dpkg 1.16.2)
446 =item B<source:Upstream-Version>
448 It contains the source package upstream version for this binary package
449 (since dpkg 1.18.16)
451 =back
453 The default format string is “B<${binary:Package}\t${Version}\n>”.
454 Actually, all other fields found in the status file (i.e. user defined
455 fields) can be requested, too. They will be printed as-is, though, no
456 conversion nor error checking is done on them. To get the name of the
457 B<dpkg> maintainer and the installed version, you could run:
459 =over
461  dpkg-query -f='${binary:Package} ${Version}\t${Maintainer}\n' \
462   -W dpkg
464 =back
466 =back
468 =head1 EXIT STATUS
470 =over
472 =item B<0>
474 The requested query was successfully performed.
476 =item B<1>
478 The requested query failed either fully or partially, due to no file or
479 package being found (except for B<--control-path>,
480 B<--control-list> and B<--control-show> were such errors are
481 fatal).
483 =item B<2>
485 Fatal or unrecoverable error due to invalid command-line usage, or
486 interactions with the system, such as accesses to the database,
487 memory allocations, etc.
489 =back
491 =head1 ENVIRONMENT
493 =head2 External environment
495 =over
497 =item B<SHELL>
499 Sets the program to execute when spawning a command via a shell
500 (since dpkg 1.19.2).
502 =item B<PAGER>
504 =item B<DPKG_PAGER>
506 Sets the pager command to use (since dpkg 1.19.1), which will be executed
507 with «B<$SHELL -c>».
508 If B<SHELL> is not set, «B<sh>» will be used instead.
509 The B<DPKG_PAGER> overrides the B<PAGER> environment variable
510 (since dpkg 1.19.2).
512 =item B<DPKG_ROOT>
514 If set and the B<--root> option has not been specified, it will
515 be used as the filesystem root directory (since dpkg 1.21.0).
517 =item B<DPKG_ADMINDIR>
519 If set and the B<--admindir> option has not been specified, it will
520 be used as the B<dpkg> data directory.
522 =item B<DPKG_DEBUG>
524 Sets the debug mask (since dpkg 1.21.10) from an octal value.
525 The currently accepted flags are described in the B<dpkg --debug> option,
526 but not all these flags might have an effect on this program.
528 =item B<DPKG_COLORS>
530 Sets the color mode (since dpkg 1.18.5).
531 The currently accepted values are: B<auto> (default), B<always> and
532 B<never>.
534 =back
536 =head2 Internal environment
538 =over
540 =item B<LESS>
542 Defined by B<dpkg-query> to “B<-FRSXMQ>”, if not already set, when
543 spawning a pager (since dpkg 1.19.2).
544 To change the default behavior, this variable can be preset to some other
545 value including an empty string, or the B<PAGER> or B<DPKG_PAGER>
546 variables can be set to disable specific options with «B<-+>», for
547 example B<DPKG_PAGER="less -+F">.
549 =back
551 =head1 SECURITY
553 Query operations should never require root, and delegating their execution
554 to unprivileged users via some gain-root command can have security
555 implications (such as privilege escalation), for example when a pager is
556 automatically invoked by the tool.
558 =head1 SEE ALSO
560 B<dpkg>(1).