pkman is a package manager utility written in C programming language, and uses (xz compressed) cpio format for packaging. pkman is inspired by the Arch Linux's pacman.
pkman keeps the system up to date by synchronizing the package database from master (or mirror) servers, and upgrading the packages while taking care of dependency packages.
The following is just a few examples that pkman can do. See the pkman --help for the complete feature set.
To install packages including their dependencies, issue the following
# pkman -S package_name_1 package_name_2 ...
To install a package from a specific repository:
# pkman -S repo_name/package_name
Installing package groups
Some packages belong to a group of packages (a package can belong to
any number of groups). To install package groups, issue the following
# pkman -S group_name_1 group_name_2 ...
To list the packages belong to a group:
$ pkman -Sg group_name_1
Multiple package names can be specified. Without any arguments, list all groups.
To remove a previously installed package leaving all its dependencies
# pkman -R package_name
Important! To upgrade a single package try to avoid pkman -Sy package_name, use pkman -Syu package_name instead.
pkman can perform a complete system upgrade, by refreshing the
databases, select the necessary package files to download and
installing them. This procedure may introduce new dependenies.
Therefore, this can take a while.
# pkman -Syu
Package databases can be refreshed by:
# pkman -Sy
To query out-of-date packages:
$ pkman -Qu
Querying package databases
pkman can search in the databases, searching in package names
and descriptions as well (EREs (Extended Regular Expressions)
are used in case insensitive mode):
$ pkman -Ss ERE_1 ERE_2...
The EREs may list a lot of unwanted results. The search can be limited
to package names only. This will exclude to search in package
$ pkman -Ss '^pk'
Without any EREs, pkman will list all available packages with
$ pkman -Ss
The search in the installed packages only:
$ pkman -Qs ERE_1 ERE_2...
To display the information page of packages:
$ pkman -Si package_name
For locally installed packages:
$ pkman -Qi package_name
Passing two -i will display more information, such as install
reason, backup files and their status:
$ pkman -Qii package_name
To list the files installed by the package:
$ pkman -Ql package_name
To list all installed packages with their version number:
$ pkman -Q
To list installed packages belong to a group:
$ pkman -Qg group_name_1
To list groups with packages that locally installed:
$ pkman -Qg
To query the database to know which package owns specific files:
$ pkman -Qo /path/to/file
To verify whether a package is installed correctly:
$ pkman -Qk package_name
Two ks will perform more checks, three ks will validate hash values (this takes some time). Without any argument, it will check all the installed packages.
To list explicitly installed packages:
$ pkman -Qe
To list packages installed as dependencies:
$ pkman -Qd
To install a "local" package (locally built or downloaded from a
# pkman -U /path/to/package/packagename-version-arch.pkg.cpio.xz
The database files are normally located at /var/lib/pkman/sync. Each repository has a single xz compressed cpio in the following format: repo.db.
Each package has one file (a single package descriptor) in the database cpio. The descriptor contains all the necessary information to identify, populate and verify the package.
Example descriptor file name in the core.db cpio: pkman-0.1-41
To list of the keys stored in the package descriptor, see the /usr/include/libpkman/pkcommon.h header, and look for defines starting with PKCOMMON_KEY_.
The pkman place the downloaded package files into /var/lib/pkman/cache.
From time to time it is recommended to clear the package cache,
since the pkman will not remove any package file from the
cache by itself.
To remove package files that are no longer needed:
# pkman -Sc
To remove all files from the cache:
# pkman -Scc
WARNING! Issue these operation only when previous package versions are not required, for example for a later downgrade. pkman -Sc will keep package files that are currently installed on the system. pkman -Scc, however, will remove all files from the cache (including non-package files).
The settings file is located at /etc/pkman/pkman.ini. This file contains the basic settings (i.e. architecture and directories), the known servers and the repositories to work with. Users can alter this file at will, but keep in mind, misconfiguration can cause damage to the system.
To add a user repository, modify the /etc/pkman/pkman.ini
by creating a new entry under the repository root:
repository.myrepo.name = "myrepo"
To add custom servers, append this:
repository.myrepo.server.mysrv = "http://example.net/threos/$repo/$arch"
Note: mysrv is the key of the server, it is for internal use only, however it must be unique.
Servers listed in repository entries will be applied before global servers.
For details, see pkman --config-help.
pkman can run hooks before and after transaction. The conditions when to arm a hooks is defined in the hook.
A hook consists of:
- short, unique name
- human readable description (optional)
- command to run
- the operation when to trigger the hook:
- when to run the hook:
- type to match the hook targets:
- list of extended regular expressions (EREs) to match against; the hook will be triggered if one of the EREs matched
- a flag to abort the transaction if the hook exits non-zero (PreTransaction only, optional)
- list of packages which must be installed to execute the hook
The hooks are located at /usr/share/libpkman/hooks. To read more about the hooks, see the /usr/include/libpkman/pkcommon.h header file.
An example hooks is available in the sync-hook in the core repository.
failed to commit transaction: One or more file conflicts found
The pkman will issue an error message if it detects file conflicts, and by design it will not overwrite files:
pkman: failed to commit transaction: One or more file conflicts found package: /path/to/file exists in filesystem
To safely resolve this, first check which package owns the conflicted
$ pkman -Qo /path/to/file
- If no package owns the file, rename it, perform the original command, and may remove after successful operation.
- If a package owns the file, file a bug report.
failed to initialize pkman context: Local database error
The pkman may issue an error message if the local database is corrupted:
pkman: dirname: entry is not a valid package descriptor pkman: failed to initialize pkman context: Local database error
Tips to fix it:
- Remove any empty directory in /var/lib/pkman/local.
- A database entry (which is a directory) contains two important
- desc: the package descriptor extended with local attributes
- files: the file catalogue with path, size, mode and the SHA2-256 hash of the file content (if it is a regular file)
Author: Aron Barath, 2017-2018