Fix search by libraries broken by recent optimizations

This commit is contained in:
Martchus 2022-06-09 18:51:03 +02:00
parent c155176098
commit 6a633252a8
1 changed files with 6 additions and 1 deletions

View File

@ -377,7 +377,7 @@ void Database::providingPackagesBase(const Dependency &dependency, bool reverse,
package = std::make_shared<PackageBase>(); package = std::make_shared<PackageBase>();
} else { } else {
package->clear(); package->clear();
}; }
if (packagesTxn.get<PackageBase>(packageID, *package) && visitor(packageID, std::move(package))) { if (packagesTxn.get<PackageBase>(packageID, *package) && visitor(packageID, std::move(package))) {
return; return;
} }
@ -412,6 +412,11 @@ void Database::providingPackagesBase(const std::string &libraryName, bool revers
auto package = std::shared_ptr<PackageBase>(); auto package = std::shared_ptr<PackageBase>();
for (auto [i, end] = providesTxn.equal_range<0>(libraryName); i != end; ++i) { for (auto [i, end] = providesTxn.equal_range<0>(libraryName); i != end; ++i) {
for (const auto packageID : i->relevantPackages) { for (const auto packageID : i->relevantPackages) {
if (!package) {
package = std::make_shared<PackageBase>();
} else {
package->clear();
}
if (packagesTxn.get<PackageBase>(packageID, *package) && visitor(packageID, std::move(package))) { if (packagesTxn.get<PackageBase>(packageID, *package) && visitor(packageID, std::move(package))) {
return; return;
} }