aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRobert Schumacher <roschuma@microsoft.com>2020-04-29 15:09:55 -0700
committerGitHub <noreply@github.com>2020-04-29 15:09:55 -0700
commit9b91a5360652bd1d5740f3e6984e702c94bf6165 (patch)
tree09532183857394170c8717c3f506a5099b7ead1d
parent6ef805c2a915cba16f5d9f1ccd38d13384f424a1 (diff)
downloadvcpkg-9b91a5360652bd1d5740f3e6984e702c94bf6165.tar.gz
vcpkg-9b91a5360652bd1d5740f3e6984e702c94bf6165.zip
[vcpkg] Correctly record default feature list in BinaryParagraphs. Fixes #10678. (#11085)
-rw-r--r--toolsrc/src/vcpkg-test/plan.cpp28
-rw-r--r--toolsrc/src/vcpkg/binaryparagraph.cpp16
-rw-r--r--toolsrc/src/vcpkg/dependencies.cpp6
3 files changed, 42 insertions, 8 deletions
diff --git a/toolsrc/src/vcpkg-test/plan.cpp b/toolsrc/src/vcpkg-test/plan.cpp
index d3d4310e9..75e8acd58 100644
--- a/toolsrc/src/vcpkg-test/plan.cpp
+++ b/toolsrc/src/vcpkg-test/plan.cpp
@@ -624,6 +624,34 @@ TEST_CASE ("do not install default features of existing dependency", "[plan]")
features_check(install_plan.install_actions.at(0), "a", {"core"}, Triplet::X64_WINDOWS);
}
+TEST_CASE ("install default features of existing dependency", "[plan]")
+{
+ // Add a port "a" which depends on the default features of "b"
+ PackageSpecMap spec_map(Triplet::X64_WINDOWS);
+ spec_map.emplace("a", "b");
+ // "b" has a default feature
+ spec_map.emplace("b", "", {{"b1", ""}}, {"b1"});
+
+ std::vector<std::unique_ptr<StatusParagraph>> status_paragraphs;
+ // "b[core]" is already installed
+ status_paragraphs.push_back(make_status_pgh("b", "", "b1"));
+ status_paragraphs.back()->package.spec = PackageSpec("b", Triplet::X64_WINDOWS);
+
+ // Install "a" (without explicit feature specification)
+ auto install_specs = FullPackageSpec::from_string("a", Triplet::X64_WINDOWS);
+ PortFileProvider::MapPortFileProvider map_port{spec_map.map};
+ MockCMakeVarProvider var_provider;
+
+ auto install_plan = Dependencies::create_feature_install_plan(map_port,
+ var_provider,
+ {install_specs.value_or_exit(VCPKG_LINE_INFO)},
+ StatusParagraphs(std::move(status_paragraphs)));
+
+ // Expect "b" to be rebuilt
+ REQUIRE(install_plan.install_actions.size() == 2);
+ features_check(install_plan.install_actions.at(0), "b", {"core", "b1"}, Triplet::X64_WINDOWS);
+}
+
TEST_CASE ("install default features of dependency test 3", "[plan]")
{
std::vector<std::unique_ptr<StatusParagraph>> status_paragraphs;
diff --git a/toolsrc/src/vcpkg/binaryparagraph.cpp b/toolsrc/src/vcpkg/binaryparagraph.cpp
index 45638e1f5..ad18b71c6 100644
--- a/toolsrc/src/vcpkg/binaryparagraph.cpp
+++ b/toolsrc/src/vcpkg/binaryparagraph.cpp
@@ -85,13 +85,14 @@ namespace vcpkg
Triplet triplet,
const std::string& abi_tag,
const std::vector<FeatureSpec>& deps)
- : version(spgh.version)
+ : spec(spgh.name, triplet)
+ , version(spgh.version)
, description(spgh.description)
, maintainer(spgh.maintainer)
, abi(abi_tag)
, type(spgh.type)
+ , default_features(spgh.default_features)
{
- this->spec = PackageSpec(spgh.name, triplet);
this->depends = Util::fmap(deps, [](const FeatureSpec& spec) { return spec.spec().name(); });
Util::sort_unique_erase(this->depends);
}
@@ -100,9 +101,14 @@ namespace vcpkg
const FeatureParagraph& fpgh,
Triplet triplet,
const std ::vector<FeatureSpec>& deps)
- : version(), description(fpgh.description), maintainer(), feature(fpgh.name), type(spgh.type)
+ : spec(spgh.name, triplet)
+ , version()
+ , description(fpgh.description)
+ , maintainer()
+ , feature(fpgh.name)
+ , type(spgh.type)
+ , default_features()
{
- this->spec = PackageSpec(spgh.name, triplet);
this->depends = Util::fmap(deps, [](const FeatureSpec& spec) { return spec.spec().name(); });
Util::sort_unique_erase(this->depends);
}
@@ -143,5 +149,7 @@ namespace vcpkg
if (!pgh.description.empty()) out_str.append("Description: ").append(pgh.description).push_back('\n');
out_str.append("Type: ").append(Type::to_string(pgh.type)).push_back('\n');
+ if (!pgh.default_features.empty())
+ out_str.append("Default-Features: ").append(Strings::join(", ", pgh.default_features)).push_back('\n');
}
}
diff --git a/toolsrc/src/vcpkg/dependencies.cpp b/toolsrc/src/vcpkg/dependencies.cpp
index 120f84aef..316429515 100644
--- a/toolsrc/src/vcpkg/dependencies.cpp
+++ b/toolsrc/src/vcpkg/dependencies.cpp
@@ -106,15 +106,13 @@ namespace vcpkg::Dependencies
&m_scfl.source_control_file->find_dependencies_for_feature(feature).value_or_exit(VCPKG_LINE_INFO);
std::vector<FeatureSpec> dep_list;
- if (maybe_vars)
+ if (auto vars = maybe_vars.get())
{
// Qualified dependency resolution is available
- auto fullspec_list = filter_dependencies(
- *qualified_deps, m_spec.triplet(), maybe_vars.value_or_exit(VCPKG_LINE_INFO));
+ auto fullspec_list = filter_dependencies(*qualified_deps, m_spec.triplet(), *vars);
for (auto&& fspec : fullspec_list)
{
- // TODO: this is incorrect and does not handle default features nor "*"
Util::Vectors::append(&dep_list, fspec.to_feature_specs({"default"}, {"default"}));
}