aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEelco Dolstra <edolstra@gmail.com>2020-07-13 20:17:00 +0200
committerEelco Dolstra <edolstra@gmail.com>2020-07-13 20:17:00 +0200
commit43b8e96d30fa2b4e5f2f5144dc905c2d944a4e15 (patch)
tree75c09f94d3b36377c8683aa71d0ad799f68dc8a2
parent9502c0e2ebec45a5615c6b570cc99de17ebb542b (diff)
Fix 'nix verify --all' on a binary cache (cached case)
-rw-r--r--src/libstore/store-api.cc16
1 files changed, 10 insertions, 6 deletions
diff --git a/src/libstore/store-api.cc b/src/libstore/store-api.cc
index bc3fafa35..5554befa4 100644
--- a/src/libstore/store-api.cc
+++ b/src/libstore/store-api.cc
@@ -351,6 +351,14 @@ ref<const ValidPathInfo> Store::queryPathInfo(const StorePath & storePath)
}
+static bool goodStorePath(const StorePath & expected, const StorePath & actual)
+{
+ return
+ expected.hashPart() == actual.hashPart()
+ && (expected.name() == Store::MissingName || expected.name() == actual.name());
+}
+
+
void Store::queryPathInfo(const StorePath & storePath,
Callback<ref<const ValidPathInfo>> callback) noexcept
{
@@ -378,7 +386,7 @@ void Store::queryPathInfo(const StorePath & storePath,
state_->pathInfoCache.upsert(hashPart,
res.first == NarInfoDiskCache::oInvalid ? PathInfoCacheValue{} : PathInfoCacheValue{ .value = res.second });
if (res.first == NarInfoDiskCache::oInvalid ||
- res.second->path != storePath)
+ !goodStorePath(storePath, res.second->path))
throw InvalidPath("path '%s' is not valid", printStorePath(storePath));
}
return callback(ref<const ValidPathInfo>(res.second));
@@ -405,11 +413,7 @@ void Store::queryPathInfo(const StorePath & storePath,
auto storePath = parseStorePath(storePathS);
- if (!info
- || info->path.hashPart() != storePath.hashPart()
- || (storePath.name() != MissingName && info->path.name() != storePath.name())
- )
- {
+ if (!info || !goodStorePath(storePath, info->path)); {
stats.narInfoMissing++;
throw InvalidPath("path '%s' is not valid", storePathS);
}