bpkg-pkg-build(1) General Commands Manual bpkg-pkg-build(1)

bpkg-pkg-build - build package

bpkg pkg-build|build [options] [--upgrade|-u | --patch|-p]
                     [cfg-var... --] pkg-spec...
bpkg pkg-build|build [options]  --upgrade|-u | --patch|-p
                     [cfg-var... --]

pkg-spec = [flags](([scheme:]pkg[ver-spec]),...[@rep-loc] |
                   [@]rep-loc                            |
                   file                                  |
                   dir/)
flags      = ?
scheme     = sys
ver-spec   = /version | version-constraint

The pkg-build command builds one or more packages including all their dependencies. Besides building new packages, this command is also used to upgrade or downgrade packages that are already present in the configuration. And unless the --keep-unused|-K option is specified, pkg-build will also drop dependency packages that would otherwise no longer be used.

The first form (one or more packages are specified) builds new or upgrades (by default or if --upgrade is specified) or patches (if --patch is specified) the specified packages. The second form (no arguments but either --upgrade or --patch is specified) upgrades or patches all the held packages in the configuration (see below for details on held package).

In both forms specifying the --immediate|-i or --recursive|-r option causes pkg-build to also upgrade or patch the immediate or all dependencies of the specified (first form) or held (second form) packages, respectively. Note also that in the first form these options can only be specified with an explicit --upgrade or --patch.

Each package can be specified as just the name (pkg) with optional version specification (ver-spec), in which case the source code for the package will be automatically fetched from one of the configured repositories. See the bpkg-rep-add(1) and bpkg-rep-fetch(1) commands for more information on package repositories. The version specification (ver-spec) can be either the exact version in the /version form or the version constraint as described in Package Version Constraint (#package-version-constraint). If ver-spec is not specified, then the latest available version will be built. To downgrade, the desired version must be specified explicitly. For example:

bpkg build foo libfoo/1.2.3 "bar < 2.0.0"

Alternatively, the package repository location (rep-loc) can be specified as part of the build command. In this case, if ver-spec is not specified, then the latest available from this repository version will be built. For example:

bpkg build foo,libfoo/1.2.3@https://git.example.org/foo.git#master

If only the location is specified, then the latest versions of all the packages available directly from this repository will be built (note that this does not include packages available from complement repositories). The @ delimiter can be omitted if the location is a URL. For example:

bpkg build https://git.example.org/foo.git#master
bpkg build @/path/to/repository/

A package name (pkg) can be prefixed with a package scheme (scheme). Currently the only recognized scheme is sys which instructs pkg-build to configure the package as available from the system rather than building it from source.

The system package version (ver-spec) may not be a version constraint but may be the special '/*' value, which indicates that the version should be considered unknown but satisfying any version constraint. If unspecified, then pkg-build will attempt to query the system package manager for the installed version unless the system package manager is unsupported or this functionality is disabled with --sys-no-query, in which case the '/*' ver-spec is assumed. If the system package manager is supported, then the automatic installation of an available package can be requested with the --sys-install option. Note that if the version is not explicitly specified, then at least a stub package must be available from one of the repositories unless the --sys-no-stub option is specified.

Finally, a package can be specified as either the path to the package archive (file) or to the package directory (dir/; note that it must end with a directory separator). See the bpkg-pkg-fetch(1) and bpkg-pkg-unpack(1) commands for more information on the semantics of specifying the package as an archive or a directory.

Additional configuration variables (cfg-var), if any, should be specified before packages (pkg-spec) and should be separated with --. Such variables are effective only when configuring and only for packages that were explicitly specified on the command line (unless global overrides). They can also be specified to only apply to specific packages using the argument grouping mechanism discussed below. See bpkg-pkg-configure(1) for more information on configuration variables.

By default a package that is specified explicitly on the command line is built to hold: it will not be considered for automatic removal if it no longer has any dependents. Only versions from repositories that were added to the configuration (bpkg-rep-add(1)) are considered as available for build to hold.

Alternatively, a package can be built (or, more commonly, upgraded/downgraded) as a dependency by specifying the ? flag (flags) or the --dependency option. Such a package will only be added to the configuration if it actually has any dependents and once no longer used, it will be automatically dropped. Only versions from prerequisite repositories of dependent packages are considered as available for build as a dependency.

Packages (both built to hold and as dependencies) that are specified with an explicit package version (ver-spec) or as an archive or directory, will have their versions held, that is, they will not be automatically upgraded.

As an illustration, let's assume in the following example that the stable repository contains packages foo 1.0.0 as well as libfoo 1.0.0 and 1.1.0 while testing – libfoo 2.0.0, that testing is complemented by stable, and that foo depends on libfoo >= 1.0.0:

bpkg fetch https://example.org/1/testing
bpkg build foo            # build foo    1.0.0 to hold
                          # build libfoo 1.1.0 as dependency
bpkg build ?libfoo/1.0.0  # downgrade libfoo 1.0.0 as dependency,
                          #           also hold version 1.0.0
bpkg build ?libfoo/2.0.0  # error: 2.0.0 unavailable in dependent's
                          #        (foo) repository (stable)
bpkg build libfoo/2.0.0   # upgrade libfoo 2.0.0 to hold,
                          #         also hold version 2.0.0

A package can be built in one of the linked configurations instead of the current (or host/build system module, for build-time dependencies) configuration by specifying one of the --config-* options (see bpkg-cfg-create(1) for background on linked configurations). For example:

bpkg build foo { --config-name=alt-host }+ ?bison

The following options (as well as additional configuration variables) can be grouped to apply to a specific pkg-spec as well as specified globally, in which case they apply to all the specified packages (see bpkg-argument-grouping(1) for details).

Upgrade packages to the latest available version that satisfies all the constraints.
Upgrade packages to the latest available patch version that satisfies all the constraints.
Replace orphaned packages with the best matching available package versions which satisfy all the constraints.

It may happen that a built package no longer has the corresponding package available in the repository it came from (for example, as a result of bpkg-rep-fetch(1) or bpkg-rep-remove(1)). Such a package is called an orphan. Without the --deorphan option, upgrading, downgrading, or patching an orphan will leave it unchanged if a more suitable version of the package is not available. If the --deorphan option is specified, then an orphan will be replaced with a non-orphan. In this case, if --upgrade, --patch, or the package version is specified, then the new version is selected accordingly. Otherwise, the closest version to the orphaned version is selected using the following preference order: (1) same version, revision, and iteration, (2) latest iteration of same version and revision, (3) later revision of same version, (4) later patch of same version, (5) later minor of same version, (6) latest available version, including earlier (see Package Version (#package-version) for details).

Also upgrade, patch, or deorphan immediate dependencies.
Also upgrade, patch, or deorphan all dependencies, recursively.
Upgrade immediate dependencies.
Patch immediate dependencies.
Deorphan immediate dependencies.
Upgrade all dependencies, recursively.
Patch all dependencies, recursively.
Deorphan all dependencies, recursively.
Build, upgrade, or downgrade a package as a dependency rather than to hold.
Keep output directories of external packages between upgrades and downgrades. Refer to bpkg-pkg-disfigure(1) for details.
Disfigure packages between upgrades and downgrades effectively causing a from-scratch reconfiguration.
Check out packages that come from version control-based repositories into the specified directory rather than into the configuration directory. Refer to the --output-root option in bpkg-pkg-checkout(1) for details.
Remove the checked out package (source) directories when the packages are purged. Refer to the --output-purge option in bpkg-pkg-checkout(1) for details.
Name of the linked configuration to build this package(s) in. By default, the package is built in the current configuration. Repeat this option to specify multiple configurations.
Numeric id of the linked configuration to build this package(s) in. By default, the package is built in the current configuration. Repeat this option to specify multiple configurations.
UUID of the linked configuration to build this package(s) in. By default, the package is built in the current configuration. Repeat this this option to specify multiple configurations.

Assume the answer to all prompts is yes. Note that this excludes the system package manager prompts; see --sys-yes for details.
Instead of the default update build system operation, perform the update-for-operation variant where operation is normally install or test.
Don't drop dependency packages that were automatically built but will no longer be used.
Update without confirmation dependent packages that are reconfigured due to their dependencies being upgraded or downgraded.
Don't offer to update dependent packages that are reconfigured due to their dependencies being upgraded or downgraded.
Configure all the packages but don't update.
Print to stdout what would be done without actually doing anything.
Print the plan (even if --yes is specified) and start it with the header line (unless it is empty).
Don't fetch repositories specified as part of the build command.
Don't re-fetch complement and prerequisite repositories of repositories specified as part of the build command. Refer to the --shallow option in bpkg-rep-fetch(1) for details.
For the duration of the command execution pretend the specified repository was removed as if by performing the rep-remove command. The repository can be specified either as a repository name or as a repository location (URL or a directory path). Note that the repository's complement and prerequisite repositories are also considered masked, recursively, unless they are complements and/or prerequisites of other unmasked repositories. Repeat this option to mask multiple repositories.
For the duration of the command execution pretend the specified repository was removed from the specified configuration. Similar to --mask-repository but only masks the repository in a single configuration. The option value is a key-value pair in the form:

config-uuid=rep

Repeat this option to mask multiple repositories.

Don't try to refine the configuration by offering to drop any unused dependencies that were potentially left behind on the previous pkg-build or pkg-drop command execution if the command is otherwise a noop (performs no new package builds, upgrades, etc).
Don't move dependency packages between configurations. In this mode the --config-* options specify packages' current rather than new locations.
Exit with the specified error code if the command execution is a noop (performs no new package builds, upgrades, etc).
Hash the names, versions, and configurations of all the packages that would be built. If the resulting checksum matches the specified, then exit without building anything (potentially with a special error code specified with the --noop-exit option). Otherwise, proceed to build as normal. In both cases, print the resulting checksum to stdout.
If no configuration of a suitable type is linked to build a build-time dependency, instead of automatically creating a private configuration of this type, exit with the specified error code printing to stdout the dependency chain starting from the build-time dependency (together with its constraint, if present) and ending with the top-level dependent (together with their configuration directories), one entry per line. For example:
yacc ^1.0.0
libbar/1.0.0 /path/to/libbar/cfg/
libfoo/1.0.0 /path/to/libfoo/cfg/

See bpkg-cfg-create(1) for details on linked configurations.

Do not query the system package manager for the installed versions of packages specified with the sys scheme.
Instruct the system package manager to install available versions of packages specified with the sys scheme that are not already installed. See also the --sys-no-fetch, --sys-yes, and --sys-sudo options.
Do not fetch the system package manager metadata before querying for available versions of packages specified with the sys scheme. This option only makes sense together with --sys-install.
Do no require a stub for packages specified with the sys scheme. Note that this option has effect only if the system package manager interactions are supported and not disabled.
Assume the answer to the system package manager prompts is yes. Note that system package manager interactions may break your system and you should normally only use this option on throw-away setups (test virtual machines, etc).
The sudo program to use for system package manager interactions that normally require administrative privileges (fetch package metadata, install packages, etc). If unspecified, sudo is used by default. Pass empty or the special false value to disable the use of the sudo program. Note that the sudo program is normally only needed if the system package installation is enabled with the --sys-install option.
Alternative system/distribution package manager to interact with. The valid name values are debian (Debian and alike, such as Ubuntu, etc) and fedora (Fedora and alike, such as RHEL, CentOS, etc). Note that some package managers may only be supported when running on certain host operating systems.
Alternative architecture to use when interacting with the system package manager. The valid name values are system/distribution package manager-specific. If unspecified, the host architecture is used.
Assume current configuration is in dir rather than in the current working directory. Repeat this option to specify multiple current configurations. If multiple configurations are specified, they need not belong to the same linked configuration cluster.

The common options are summarized below with a more detailed description available in bpkg-common-options(1).

Print essential underlying commands being executed.
Print all underlying commands being executed.
Run quietly, only printing error messages.
Set the diagnostics verbosity to level between 0 and 6.
Representation format to use for printing to stdout.
Number of jobs to perform in parallel.
Don't print informational messages about the outcome of performing a command or some of its parts.
Write the result of performing a command in a structured form.
Display progress indicators for long-lasting operations, such as network transfers, building, etc.
Suppress progress indicators for long-lasting operations, such as network transfers, building, etc.
Use color in diagnostics.
Don't use color in diagnostics.
The build program to be used to build packages.
Additional option to be passed to the build program.
The fetch program to be used to download resources.
Additional option to be passed to the fetch program.
The fetch and fetch-like (for example, git) program timeout.
HTTP proxy server to use when fetching package manifests and archives from remote pkg repositories.
The git program to be used to fetch git repositories.
Additional common option to be passed to the git program.
The sha256 program to be used to calculate SHA256 sums.
Additional option to be passed to the sha256 program.
The tar program to be used to extract package archives.
Additional option to be passed to the tar program.
The openssl program to be used for crypto operations.
Additional option to be passed to the openssl program.
Types of repositories to authenticate.
Trust repository certificate with a SHA256 fingerprint.
Assume the answer to all authentication prompts is yes.
Assume the answer to all authentication prompts is no.
Protocol capabilities (pc) for a git repository URL prefix (up).
The pager program to be used to show long text.
Additional option to be passed to the pager program.
Read additional options from file.
The directory to load additional default options files from.
Don't load default options files.
Don't remove the bpkg's temporary directory at the end of the command execution and print its path at the verbosity level 2 or higher.

See bpkg-default-options-files(1) for an overview of the default options files. For the pkg-build command the search start directory is the configuration directory. The following options files are searched for in each directory and, if found, loaded in the order listed:

bpkg.options
bpkg-pkg-build.options

The following pkg-build command options cannot be specified in the default options files:

--directory|-d

Send bug reports to the users@build2.org mailing list.

Copyright (c) 2014-2024 the build2 authors.

Permission is granted to copy, distribute and/or modify this document under the terms of the MIT License.

June 2024 bpkg 0.17.0