Use the StorePath-based cache interface

This commit is contained in:
Eelco Dolstra 2023-11-22 11:44:02 +01:00
parent 61b76f5f34
commit b1ab592f28

View file

@ -26,12 +26,9 @@ StorePath InputAccessor::fetchToStore(
{"method", (uint8_t) method}, {"method", (uint8_t) method},
{"path", path.abs()} {"path", path.abs()}
}; };
if (auto res = fetchers::getCache()->lookup(*cacheKey)) { if (auto res = fetchers::getCache()->lookup(store, *cacheKey)) {
StorePath storePath{fetchers::getStrAttr(*res, "storePath")}; debug("store path cache hit for '%s'", showPath(path));
if (store->isValidPath(storePath)) { return res->second;
debug("store path cache hit for '%s'", showPath(path));
return storePath;
}
} }
} else } else
debug("source path '%s' is uncacheable", showPath(path)); debug("source path '%s' is uncacheable", showPath(path));
@ -51,9 +48,7 @@ StorePath InputAccessor::fetchToStore(
: store->addToStoreFromDump(*source, name, method, htSHA256, repair); : store->addToStoreFromDump(*source, name, method, htSHA256, repair);
if (cacheKey) if (cacheKey)
fetchers::getCache()->upsert( fetchers::getCache()->add(store, *cacheKey, {}, storePath, true);
*cacheKey,
fetchers::Attrs{{"storePath", std::string(storePath.to_string())}});
return storePath; return storePath;
} }