// file : bpkg/pkg-configure.hxx -*- C++ -*- // license : MIT; see accompanying LICENSE file #ifndef BPKG_PKG_CONFIGURE_HXX #define BPKG_PKG_CONFIGURE_HXX #include // version #include #include #include // transaction, selected_package #include #include // package_prerequisites, // dependencies. #include #include 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&, const dependencies&, const vector* alternatives, package_skeleton&&, const vector* prerequisites, bool simulate, const function& = {}); // Configure a system package and commit the transaction. // shared_ptr pkg_configure_system (const package_name&, const version&, database&, transaction&); } #endif // BPKG_PKG_CONFIGURE_HXX