aboutsummaryrefslogtreecommitdiff
path: root/toolsrc/src
diff options
context:
space:
mode:
authorRobert Schumacher <roschuma@microsoft.com>2018-02-16 21:32:07 -0800
committerGitHub <noreply@github.com>2018-02-16 21:32:07 -0800
commit7ed5eb18ec729b74cfae216653be34420cd19a98 (patch)
treef3161a31a224c778b2051963789f54b312e28bd7 /toolsrc/src
parent0822a28059badbb18f301b414222e869845087fb (diff)
parentf1ce125a28c98fd5a87bf509ac965b06c219d8f3 (diff)
downloadvcpkg-7ed5eb18ec729b74cfae216653be34420cd19a98.tar.gz
vcpkg-7ed5eb18ec729b74cfae216653be34420cd19a98.zip
Merge pull request #2817 from Squareys/fix-build-with-feature-deps
* [vcpkg] Add find/find_installed/is_installed for FeatureSpec Signed-off-by: Squareys <squareys@googlemail.com> * [vcpkg] Fix build command for packages that depend of features Signed-off-by: Squareys <squareys@googlemail.com>
Diffstat (limited to 'toolsrc/src')
-rw-r--r--toolsrc/src/tests.statusparagraphs.cpp33
-rw-r--r--toolsrc/src/vcpkg/build.cpp13
-rw-r--r--toolsrc/src/vcpkg/statusparagraphs.cpp19
3 files changed, 60 insertions, 5 deletions
diff --git a/toolsrc/src/tests.statusparagraphs.cpp b/toolsrc/src/tests.statusparagraphs.cpp
index 0d5324a8c..fa0d54fac 100644
--- a/toolsrc/src/tests.statusparagraphs.cpp
+++ b/toolsrc/src/tests.statusparagraphs.cpp
@@ -77,6 +77,39 @@ Status: purge ok not-installed
auto it = status_db.find_installed(unsafe_pspec("ffmpeg", Triplet::X64_WINDOWS));
Assert::IsTrue(it != status_db.end());
+
+ // Feature "openssl" is not installed and should not be found
+ auto it1 = status_db.find_installed({unsafe_pspec("ffmpeg", Triplet::X64_WINDOWS), "openssl"});
+ Assert::IsTrue(it1 == status_db.end());
+ }
+
+ TEST_METHOD(find_for_feature_packages)
+ {
+ auto pghs = parse_paragraphs(R"(
+Package: ffmpeg
+Version: 3.3.3
+Architecture: x64-windows
+Multi-Arch: same
+Description:
+Status: install ok installed
+
+Package: ffmpeg
+Feature: openssl
+Depends: openssl
+Architecture: x64-windows
+Multi-Arch: same
+Description:
+Status: install ok installed
+)");
+ Assert::IsTrue(!!pghs);
+ if (!pghs) return;
+
+ StatusParagraphs status_db(Util::fmap(
+ *pghs.get(), [](RawParagraph& rpgh) { return std::make_unique<StatusParagraph>(std::move(rpgh)); }));
+
+ // Feature "openssl" is installed and should therefore be found
+ auto it = status_db.find_installed({unsafe_pspec("ffmpeg", Triplet::X64_WINDOWS), "openssl"});
+ Assert::IsTrue(it != status_db.end());
}
};
}
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))
{
}
diff --git a/toolsrc/src/vcpkg/statusparagraphs.cpp b/toolsrc/src/vcpkg/statusparagraphs.cpp
index 475f86279..b23d8b884 100644
--- a/toolsrc/src/vcpkg/statusparagraphs.cpp
+++ b/toolsrc/src/vcpkg/statusparagraphs.cpp
@@ -83,12 +83,31 @@ namespace vcpkg
}
}
+ StatusParagraphs::const_iterator StatusParagraphs::find_installed(const FeatureSpec& spec) const
+ {
+ auto it = find(spec);
+ if (it != end() && (*it)->is_installed())
+ {
+ return it;
+ }
+ else
+ {
+ return end();
+ }
+ }
+
bool vcpkg::StatusParagraphs::is_installed(const PackageSpec& spec) const
{
auto it = find(spec);
return it != end() && (*it)->is_installed();
}
+ bool vcpkg::StatusParagraphs::is_installed(const FeatureSpec& spec) const
+ {
+ auto it = find(spec);
+ return it != end() && (*it)->is_installed();
+ }
+
StatusParagraphs::iterator StatusParagraphs::insert(std::unique_ptr<StatusParagraph> pgh)
{
Checks::check_exit(VCPKG_LINE_INFO, pgh != nullptr, "Inserted null paragraph");