1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
// file : bpkg/pkg-configure.hxx -*- C++ -*-
// license : MIT; see accompanying LICENSE file
#ifndef BPKG_PKG_CONFIGURE_HXX
#define BPKG_PKG_CONFIGURE_HXX
#include <libbpkg/manifest.hxx> // version
#include <libbpkg/package-name.hxx>
#include <bpkg/types.hxx>
#include <bpkg/forward.hxx> // transaction, selected_package
#include <bpkg/utility.hxx>
#include <bpkg/package.hxx> // package_prerequisites,
// dependencies.
#include <bpkg/package-skeleton.hxx>
#include <bpkg/pkg-configure-options.hxx>
namespace bpkg
{
int
pkg_configure (const pkg_configure_options&, cli::scanner& args);
// The custom search function. If specified, it is called by pkg_configure()
// to obtain the database to search for the prerequisite in, instead of
// searching for it in the linked databases, recursively. If the function
// returns NULL, then fallback to the recursive search through the linked
// databases.
//
using find_database_function = database* (database&,
const package_name&,
bool buildtime);
// Configure the package, update its state, and commit the transaction.
//
// The package dependency constraints are expected to be complete.
//
// The dependencies argument may contain pre-selected dependency
// alternatives (with the potential empty entries for the toolchain
// build-time dependencies or for dependencies with all the alternatives
// disabled; see pkg-build for the use-case). In this case the number of
// dependency alternatives for each dependency must be 1 (or 0) and the
// alternatives argument must be specified. The alternatives argument must
// be parallel to the dependencies argument and specify indexes of the
// selected alternatives.
//
// If prerequisites corresponding to the previous configured state of the
// package are specified, then for each depends value try to select an
// alternative where dependencies all belong to this list (the "recreate
// dependency decisions" mode). Failed that, select an alternative as if no
// prerequisites are specified (the "make dependency decisions" mode).
//
void
pkg_configure (const common_options&,
database&,
transaction&,
const shared_ptr<selected_package>&,
const dependencies&,
const vector<size_t>* alternatives,
package_skeleton&&,
const vector<package_name>* prerequisites,
bool simulate,
const function<find_database_function>& = {});
// Configure a system package and commit the transaction.
//
shared_ptr<selected_package>
pkg_configure_system (const package_name&,
const version&,
database&,
transaction&);
}
#endif // BPKG_PKG_CONFIGURE_HXX
|