an alpm .files metadata explorer
C Perl Python Shell
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Failed to load latest commit information.
m4 rewrite buildsys with autotools Jul 18, 2012
src update: condense some logic Feb 13, 2015
systemd *actually* remove the RO/RW restrictions Jun 30, 2014
.gitignore rewrite buildsys with autotools Jul 18, 2012
INSTALL link against tcmalloc if its available Sep 10, 2012 Add command_not_found_handler for fish shell Sep 14, 2014
README.pod rewrite buildsys with autotools Jul 18, 2012 prepare v15 Jul 1, 2014



pkgfile - an alpm .files metadata explorer


Usage: pkgfile [operation] [options] target


pkgfile searches the .files metadata created by repo-add(8) to retrieve file information about packages. By default, the provided target is considered to be a filename and pkgfile will return the package(s) which contain this file. The repos which pkgfile searches is determined by those enabled in /etc/pacman.conf.


-l, --list

The target is considered to be a package name rather than a filename, and the contents of the named package are returned. This allows for repo/package style syntax (such as "core/pacman") to limit the breadth of the search, but only when --list is used without the --glob or --regex options.

-s, --search

Search for packages containing the provided target. This is the default mode of operation.

-u, --update

Update the stored metadata files. It is recommended to create a daily cron job with this command to ensure accurate results. By default, only repos which are found to be newer on the mirror will be downloaded. Pass this option twice to force all repos to be downloaded.


-b, --binaries

Return only files which are contained within a bin or sbin directory.

-d, --directories

Match directories in search results.

-g, --glob

Enable shell-style glob pattern matching. See glob(7).

-i, --ignorecase

Disable case sensitivity in matching.

-r, --regex

Enable regular expression matching. See pcre(3).

-R REPO, --repo=REPO

Search only the specific repo.


-0, --null

Delimit output with null bytes rather than newline characters.

-q, --quiet

Output less. This applies to the --list operation.

-v, --verbose

Output more. This applies to the --search operation.

-w, --raw

Avoid justification of 2 column output.


-z, --compress[=COMPRESSION]

Repack downloaded repos with the optionally supplied compression method, which may be one of none, gzip, bzip2, lzo, lzma, or xz. If this flag is passed without a compression method, this defaults to gzip. If this flag is not passed at all, no compression will be applied. Applying any form of compression will decrease performance, but may be desirable for disk space concerns.


-C FILE, --config=FILE

Use a config file other than the default of /etc/pacman.conf.

-h, --help

Print help and exit.

-V, --version

Print the version and exit.


In --search mode and without the --regex or --glob option, pkgfile will attempt to match the provided target as an exact filename. If the target contains a '/' character, a full path match will be attempted. With --regex and --glob enabled searching, pkgfile will always match against the full pathname.

In --list mode and without the --regex or --glob option, pkgfile will attempt to match the provided target as an exact package name. If the target contains a '/' character, the text before the slash will be assumed to be a repository and the search will be restricted.



Storage location for metadata.


zsh, bash and fish compatible functions which can be included in shell initalization to run pkgfile when an executed command is not found.


pkgfile includes systemd timer and service units to automate periodic updates to the .files DBs. Assuming that pkgfile was built with systemd support, this can be enabled with:

  systemctl enable pkgfile-update.timer && systemctl start pkgfile-update.timer


repo-add(8), pcre(3), glob(7), pacman.conf(5)


Dave Reisner <>