Fix search by libraries broken by recent optimizations
This commit is contained in:
parent
c155176098
commit
6a633252a8
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue