mirror of
https://github.com/microsoft/vcpkg.git
synced 2025-01-15 11:18:03 +08:00
[vcpkg] Fix exporting packages with features-depending-on-features
This commit is contained in:
parent
a7c93cd73e
commit
ef4febc7ef
@ -28,10 +28,6 @@ namespace vcpkg
|
||||
|
||||
static std::vector<PackageSpec> to_package_specs(const std::vector<std::string>& ports, const Triplet& triplet);
|
||||
|
||||
static std::vector<PackageSpec> from_dependencies_of_port(const std::string& port,
|
||||
const std::vector<std::string>& dependencies,
|
||||
const Triplet& triplet);
|
||||
|
||||
const std::string& name() const;
|
||||
|
||||
const Triplet& triplet() const;
|
||||
|
@ -112,27 +112,6 @@ namespace vcpkg
|
||||
});
|
||||
}
|
||||
|
||||
std::vector<PackageSpec> PackageSpec::from_dependencies_of_port(const std::string& port,
|
||||
const std::vector<std::string>& dependencies,
|
||||
const Triplet& triplet)
|
||||
{
|
||||
return Util::fmap(dependencies, [&](const std::string& spec_as_string) -> PackageSpec {
|
||||
auto maybe_spec = PackageSpec::from_name_and_triplet(spec_as_string, triplet);
|
||||
if (auto spec = maybe_spec.get())
|
||||
{
|
||||
return std::move(*spec);
|
||||
}
|
||||
|
||||
const PackageSpecParseResult error_type = maybe_spec.error();
|
||||
Checks::exit_with_message(VCPKG_LINE_INFO,
|
||||
"Invalid dependency [%s] in package [%s]\n"
|
||||
"%s",
|
||||
spec_as_string,
|
||||
port,
|
||||
vcpkg::to_string(error_type));
|
||||
});
|
||||
}
|
||||
|
||||
const std::string& PackageSpec::name() const { return this->m_name; }
|
||||
|
||||
const Triplet& PackageSpec::triplet() const { return this->m_triplet; }
|
||||
|
@ -86,13 +86,42 @@ namespace vcpkg
|
||||
}
|
||||
std::vector<PackageSpec> InstalledPackageView::dependencies() const
|
||||
{
|
||||
// accumulate all features in installed dependencies
|
||||
// Todo: make this unneeded by collapsing all package dependencies into the core package
|
||||
auto deps = Util::fmap_flatten(features, [](const StatusParagraph* pgh) -> std::vector<std::string> const& {
|
||||
return pgh->package.depends;
|
||||
});
|
||||
|
||||
// Add the core paragraph dependencies to the list
|
||||
deps.insert(deps.end(), core->package.depends.begin(), core->package.depends.end());
|
||||
|
||||
auto&& spec = core->package.spec;
|
||||
return PackageSpec::from_dependencies_of_port(spec.name(), deps, spec.triplet());
|
||||
|
||||
// <hack>
|
||||
// This is a hack to work around existing installations that put featurespecs into binary packages
|
||||
// (example: curl[core])
|
||||
for (auto&& dep : deps)
|
||||
{
|
||||
dep.erase(std::find(dep.begin(), dep.end(), '['), dep.end());
|
||||
}
|
||||
Util::unstable_keep_if(deps, [&](auto&& e) { return e != spec.name(); });
|
||||
// </hack>
|
||||
Util::sort_unique_erase(deps);
|
||||
|
||||
return Util::fmap(deps, [&](const std::string& dep) -> PackageSpec {
|
||||
auto maybe_dependency_spec = PackageSpec::from_name_and_triplet(dep, spec.triplet());
|
||||
if (auto dependency_spec = maybe_dependency_spec.get())
|
||||
{
|
||||
return std::move(*dependency_spec);
|
||||
}
|
||||
|
||||
const PackageSpecParseResult error_type = maybe_dependency_spec.error();
|
||||
Checks::exit_with_message(VCPKG_LINE_INFO,
|
||||
"Invalid dependency [%s] in package [%s]\n"
|
||||
"%s",
|
||||
dep,
|
||||
spec.name(),
|
||||
vcpkg::to_string(error_type));
|
||||
});
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user