aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSquareys <squareys@googlemail.com>2018-02-16 14:27:32 +0100
committerSquareys <squareys@googlemail.com>2018-02-16 14:27:59 +0100
commitf1ce125a28c98fd5a87bf509ac965b06c219d8f3 (patch)
treedbe22888b9a5a617dff4f5c9c0e83a5002f96187
parent16faed678540be37ea623fa7f0f2c2e7c442b147 (diff)
downloadvcpkg-f1ce125a28c98fd5a87bf509ac965b06c219d8f3.tar.gz
vcpkg-f1ce125a28c98fd5a87bf509ac965b06c219d8f3.zip
[vcpkg] Fix build command for packages that depend of features
Signed-off-by: Squareys <squareys@googlemail.com>
-rw-r--r--toolsrc/include/vcpkg/build.h4
-rw-r--r--toolsrc/src/vcpkg/build.cpp13
2 files changed, 10 insertions, 7 deletions
diff --git a/toolsrc/include/vcpkg/build.h b/toolsrc/include/vcpkg/build.h
index e3f8bf79e..d7c5c8344 100644
--- a/toolsrc/include/vcpkg/build.h
+++ b/toolsrc/include/vcpkg/build.h
@@ -104,11 +104,11 @@ namespace vcpkg::Build
struct ExtendedBuildResult
{
ExtendedBuildResult(BuildResult code);
- ExtendedBuildResult(BuildResult code, std::vector<PackageSpec>&& unmet_deps);
+ ExtendedBuildResult(BuildResult code, std::vector<FeatureSpec>&& unmet_deps);
ExtendedBuildResult(BuildResult code, std::unique_ptr<BinaryControlFile>&& bcf);
BuildResult code;
- std::vector<PackageSpec> unmet_dependencies;
+ std::vector<FeatureSpec> unmet_dependencies;
std::unique_ptr<BinaryControlFile> binary_control_file;
};
diff --git a/toolsrc/src/vcpkg/build.cpp b/toolsrc/src/vcpkg/build.cpp
index 7de276f4f..cc376c773 100644
--- a/toolsrc/src/vcpkg/build.cpp
+++ b/toolsrc/src/vcpkg/build.cpp
@@ -267,13 +267,16 @@ namespace vcpkg::Build
const Triplet& triplet = config.triplet;
{
- std::vector<PackageSpec> missing_specs;
+ std::vector<FeatureSpec> missing_specs;
for (auto&& dep : filter_dependencies(config.scf.core_paragraph->depends, triplet))
{
- auto dep_spec = PackageSpec::from_name_and_triplet(dep, triplet).value_or_exit(VCPKG_LINE_INFO);
- if (!status_db.is_installed(dep_spec))
+ auto dep_specs = FeatureSpec::from_strings_and_triplet({dep}, triplet);
+ for (auto&& feature : dep_specs)
{
- missing_specs.push_back(std::move(dep_spec));
+ if (!status_db.is_installed(feature))
+ {
+ missing_specs.push_back(std::move(feature));
+ }
}
}
// Fail the build if any dependencies were missing
@@ -600,7 +603,7 @@ namespace vcpkg::Build
: code(code), binary_control_file(std::move(bcf))
{
}
- ExtendedBuildResult::ExtendedBuildResult(BuildResult code, std::vector<PackageSpec>&& unmet_deps)
+ ExtendedBuildResult::ExtendedBuildResult(BuildResult code, std::vector<FeatureSpec>&& unmet_deps)
: code(code), unmet_dependencies(std::move(unmet_deps))
{
}