// 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 // variable_overrides #include #include // transaction, selected_package #include #include // package_prerequisites, // dependencies. #include #include namespace bpkg { int pkg_configure (const pkg_configure_options&, cli::scanner& args); // Configure a system package and commit the transaction. // shared_ptr pkg_configure_system (const package_name&, const version&, database&, transaction&); // 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); // Given dependencies of a package, return its prerequisite packages, // 1-based indexes of the selected dependency alternatives (0 for toolchain // build-time dependencies, etc), configuration variables that resulted from // selection of these prerequisites (import, reflection, etc), and sources // of the configuration variables resulted from evaluating the reflect // clauses. Fail if for some of the dependency alternative lists there is no // satisfactory alternative (all its dependencies are configured, satisfy // the respective constraints, etc). // // 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 the dependency alternatives are not pre-selected (alternatives == // NULL), then for each depends value select the first satisfactory // alternative encountered. If, however, prerequisites corresponding to the // previous configured state of the package are specified // (prev_prerequisites != NULL), 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). // // Note that there are actually 3 possible use cases for // pkg_configure_prerequisites(): // // - The package is being configured manually. In this case its dependency // alternatives are not pre-selected and there is no information about its // previous configured state (alternatives == NULL, prev_prerequisites == // NULL). // // - The package is being built, upgraded, or re-evaluated. In this case its // dependency alternatives are pre-selected, their enable, prefer, and // require clauses are evaluated, and there is no need in the previous // configured state information (alternatives != NULL, prev_prerequisites // == NULL). // // - The package is being reconfigured for a reason other than any of the // mentioned above (dependency up/down-grade/reconfiguration, deorphaning, // pkg-build --disfigure is specified, etc). In this case its dependency // alternatives are not pre-selected but the previous configured state // information is provided (alternatives == NULL, prev_prerequisites != // NULL). // // - There are no use cases when both dependency alternatives are // pre-selected and the previous configured state information needs to be // provided. Thus, alternatives and prev_prerequisites must never be both // NULL. // // Optionally, remove constraints from the specified dependencies // (unconstrain_deps). Only allowed in the simulation mode. // struct configure_prerequisites_result { package_prerequisites prerequisites; vector dependency_alternatives; strings config_variables; // Note: name and value. // Only contains sources of configuration variables collected using the // package skeleton, excluding those user-specified variables which are // not the project variables for the specified package (module // configuration variables, etc). Thus, it is not parallel to the // config_variables member. // vector config_sources; // Note: name and source. // SHA256 checksum of variables (names and values) referred to by the // config_sources member. // string config_checksum; }; // Return the "would be" state for packages that would be configured // by this stage. // using find_package_state_function = optional> ( const shared_ptr&); // Note: loads selected packages. // configure_prerequisites_result pkg_configure_prerequisites ( const common_options&, database&, transaction&, const dependencies&, const vector* alternatives, package_skeleton&&, const vector* prev_prerequisites, bool simulate, const function&, const function&, const vector* unconstrain_deps = nullptr); // Configure the package, update its state, and commit the transaction. // // This is a lower-level version meant for sharing the same build context // to configure multiple packages (in the dependency order). // // Note: variable_overrides must include config.config.disfigure, if // required. // // Note: expects all the non-external packages to be configured to be // already unpacked (for subproject discovery). // void pkg_configure (const common_options&, database&, transaction&, const shared_ptr&, configure_prerequisites_result&&, const unique_ptr&, const build2::variable_overrides&, bool simulate); // Create a build context suitable for configuring packages. // unique_ptr pkg_configure_context ( const common_options&, strings&& cmd_vars, const function& = nullptr); // This is a higher-level version meant for configuring a single package. // // Note: loads selected packages. // void pkg_configure (const common_options&, database&, transaction&, const shared_ptr&, const dependencies&, const vector* alternatives, package_skeleton&&, const vector* prev_prerequisites, bool disfigured, bool simulate, const function& = {}); } #endif // BPKG_PKG_CONFIGURE_HXX