// file : bpkg/pkg-build.cli // copyright : Copyright (c) 2014-2017 Code Synthesis Ltd // license : MIT; see accompanying LICENSE file include ; "\section=1" "\name=bpkg-pkg-build" "\summary=build package" namespace bpkg { { " ", "\h|SYNOPSIS| \c{\b{bpkg pkg-build}|\b{build} [] [\b{--upgrade}|\b{-u} | \b{--patch}|\b{-p}] ...\n \b{bpkg pkg-build}|\b{build} [] \ \b{--upgrade}|\b{-u} | \b{--patch}|\b{-p}} \c{ = [](([\b{:}][\b{/}])\b{,}...[\b{@}] | \n \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ [\b{@}] \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | \n \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | \n \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \b{/})\n \ \ \ \ = \b{?}\n \ \ = \b{sys}} \h|DESCRIPTION| The \cb{pkg-build} command builds one or more packages including all their prerequisites. Besides building new packages, this command is also used to upgrade or downgrade packages that are already present in the configuration. The first form (one or more packages are specified) builds new or upgrades (by default or if \cb{--upgrade} is specified) or patches (if \cb{--patch} is specified) the specified packages. The second form (no arguments but either \cb{--upgrade} or \cb{--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 \c{\b{--immediate}|\b{-i}} or \c{\b{--recursive}|\b{-r}} option causes \cb{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 \cb{--upgrade} or \cb{--patch}. Each package can be specified as just the name () with optional package version () in which case the source code for the package will be automatically fetched from one of the configured repositories. See the \l{bpkg-rep-add(1)} and \l{bpkg-rep-fetch(1)} commands for more information on package repositories. If 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 \ Alternatively, the package repository location () can be specified as part of the build command. In this case, if 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 \cb{@} 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 () can be prefixed with a package scheme (). Currently the only recognized scheme is \cb{sys} which instructs \cb{pkg-build} to configure the package as available from the system rather than building it from source. If the system package version () is not specified, then it is considered to be unknown but satisfying any dependency constraint. Such a version is displayed as '\cb{*}'. Finally, a package can be specified as either the path to the package archive () or to the package directory (\cb{/}; note that it must end with a directory separator). See the \l{bpkg-pkg-fetch(1)} and \l{bpkg-pkg-unpack(1)} commands for more information on the semantics of specifying the package as an archive or a directory. By default a package that is specified explicitly on the command line is built to \i{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 (\l{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 \i{dependency} by specifying the \cb{?} flag () or the \cb{--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 dependents) that are specified with an explicit package version () 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 \cb{foo} \cb{1.0.0} as well as \cb{libfoo} \cb{1.0.0} and \cb{1.1.0} while testing \- \cb{libfoo} \cb{2.0.0}, that testing is complemented by stable, and that \cb{foo} depends on \cb{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 \ " } class pkg_build_pkg_options { "\h|PKG-BUILD PACKAGE OPTIONS| The following options can be grouped to apply to a specific \ci{pkg-spec} as well as specified globally, in which case they apply to all the specified packages." bool --upgrade|-u { "Upgrade packages to the latest available version that satisfies all the constraints." } bool --patch|-p { "Upgrade packages to the latest available patch version that satisfies all the constraints." } bool --immediate|-i { "Also upgrade or patch immediate dependencies." } bool --recursive|-r { "Also upgrade or patch all dependencies, recursively." } bool --dependency { "Build, upgrade, or downgrade a package as a dependency rather than to hold." } bool --keep-out { "Keep output directories of external packages between upgrades and downgrades. Refer to \l{bpkg-pkg-disfigure(1)} for details." } }; class pkg_build_options: configuration_options, pkg_build_pkg_options { "\h|PKG-BUILD GLOBAL OPTIONS|" bool --yes|-y { "Assume the answer to all prompts is \cb{yes}." } string --for|-f { "", "Instead of the default \cb{update} build system operation, perform the \cb{update-for-} variant where is normally \cb{install} or \cb{test}." } bool --drop-prerequisite|-D { "Drop without confirmation prerequsite packages that were automatically built and will no longer be necessary." } bool --keep-prerequisite|-K { "Don't offer to drop prerequsite packages that were automatically built and will no longer be necessary." } bool --update-dependent|-U { "Update without confirmation dependent packages that are reconfigured due to their prerequisites being upgraded or downgraded." } bool --leave-dependent|-L { "Don't offer to update dependent packages that are reconfigured due to their prerequisites being upgraded or downgraded." } bool --configure-only|-c { "Configure all the packages but don't update." } bool --print-only|-p { "Print to \cb{STDOUT} what would be done without actually doing anything." } bool --no-fetch { "Don't fetch repositories specified as part of the build command." } bool --fetch-shallow { "Don't re-fetch complement and prerequisite repositories of repositories specified as part of the build command. Refer to the \cb{--shallow} option in \l{bpkg-rep-fetch(1)} for details." } }; }