Update generate-programs-index to handle .ls

This commit is contained in:
Eelco Dolstra 2017-04-18 16:41:11 +02:00
parent dd0d2d2ca6
commit 3daca6b592
No known key found for this signature in database
GPG key ID: 8170B4726D7198DE

View file

@ -14,6 +14,7 @@
#include "sqlite.hh" #include "sqlite.hh"
#include "download.hh" #include "download.hh"
#include "compression.hh" #include "compression.hh"
#include "binary-cache-store.hh"
#include <nlohmann/json.hpp> #include <nlohmann/json.hpp>
@ -72,7 +73,7 @@ void mainWrapped(int argc, char * * argv)
auto localStore = openStore(); auto localStore = openStore();
std::string binaryCacheUri = argv[3]; std::string binaryCacheUri = argv[3];
if (hasSuffix(binaryCacheUri, "/")) binaryCacheUri.pop_back(); if (hasSuffix(binaryCacheUri, "/")) binaryCacheUri.pop_back();
auto binaryCache = openStore(binaryCacheUri); auto binaryCache = openStore(binaryCacheUri).cast<BinaryCacheStore>();
struct CacheState struct CacheState
{ {
@ -121,6 +122,8 @@ void mainWrapped(int argc, char * * argv)
Sync<ProgramsState> programsState_; Sync<ProgramsState> programsState_;
unlink(programsDbPath.c_str());
{ {
auto programsState(programsState_.lock()); auto programsState(programsState_.lock());
@ -136,7 +139,7 @@ void mainWrapped(int argc, char * * argv)
EvalState state({}, localStore); EvalState state({}, localStore);
Value vRoot; Value vRoot;
state.eval(state.parseExprFromFile(resolveExprPath(nixpkgsPath)), vRoot); state.eval(state.parseExprFromFile(resolveExprPath(absPath(nixpkgsPath))), vRoot);
/* Get all derivations. */ /* Get all derivations. */
DrvInfos packages; DrvInfos packages;
@ -195,25 +198,6 @@ void mainWrapped(int argc, char * * argv)
} }
} }
/* It's not in the cache, so get the .ls.xz file (which
contains a JSON serialisation of the listing of the NAR
contents) from the binary cache. */
auto now1 = std::chrono::steady_clock::now();
DownloadRequest req(binaryCacheUri + "/" + storePathToHash(storePath) + ".ls.xz");
req.showProgress = DownloadRequest::no;
json ls;
try {
ls = json::parse(*decompress("xz", *getDownloader()->download(req).data));
} catch (std::invalid_argument & e) {
// FIXME: some filenames have non-UTF8 characters in them,
// which is not supported by nlohmann::json. So we have to
// skip the entire package.
throw BadJSON(e.what());
}
if (ls.value("version", 0) != 1)
throw Error("NAR index for %s has an unsupported version", storePath);
std::function<void(const std::string &, json &)> recurse; std::function<void(const std::string &, json &)> recurse;
recurse = [&](const std::string & relPath, json & v) { recurse = [&](const std::string & relPath, json & v) {
@ -238,7 +222,28 @@ void mainWrapped(int argc, char * * argv)
files[relPath] = st; files[relPath] = st;
}; };
/* It's not in the cache, so get the .ls.xz file (which
contains a JSON serialisation of the listing of the NAR
contents) from the binary cache. */
auto now1 = std::chrono::steady_clock::now();
auto s = binaryCache->getFile(storePathToHash(storePath) + ".ls");
if (!s)
printInfo("warning: no listing of %s in binary cache", storePath);
else {
try {
json ls = json::parse(*s);
if (ls.value("version", 0) != 1)
throw Error("NAR index for %s has an unsupported version", storePath);
recurse("", ls.at("root")); recurse("", ls.at("root"));
} catch (std::invalid_argument & e) {
// FIXME: some filenames have non-UTF8 characters in them,
// which is not supported by nlohmann::json. So we have to
// skip the entire package.
throw BadJSON(e.what());
}
}
/* Insert the store path into the database. */ /* Insert the store path into the database. */
{ {
@ -301,8 +306,6 @@ void mainWrapped(int argc, char * * argv)
txn.commit(); txn.commit();
} }
} catch (DownloadError & e) {
printInfo("warning: no listing of %s (%s) in binary cache", package->attrPath, storePath);
} catch (BadJSON & e) { } catch (BadJSON & e) {
printError("error: in %s (%s): %s", package->attrPath, storePath, e.what()); printError("error: in %s (%s): %s", package->attrPath, storePath, e.what());
} }