aboutsummaryrefslogtreecommitdiff
path: root/src/libstore
diff options
context:
space:
mode:
Diffstat (limited to 'src/libstore')
-rw-r--r--src/libstore/binary-cache-store.cc35
-rw-r--r--src/libstore/nar-accessor.cc33
-rw-r--r--src/libstore/nar-accessor.hh4
3 files changed, 38 insertions, 34 deletions
diff --git a/src/libstore/binary-cache-store.cc b/src/libstore/binary-cache-store.cc
index 67607ab3d..9c6424a49 100644
--- a/src/libstore/binary-cache-store.cc
+++ b/src/libstore/binary-cache-store.cc
@@ -119,42 +119,9 @@ void BinaryCacheStore::addToStore(const ValidPathInfo & info, const ref<std::str
accessor_->addToCache(info.path, *nar);
}
- std::function<void(const Path &, JSONPlaceholder &)> recurse;
-
- recurse = [&](const Path & path, JSONPlaceholder & res) {
- auto st = narAccessor->stat(path);
-
- auto obj = res.object();
-
- switch (st.type) {
- case FSAccessor::Type::tRegular:
- obj.attr("type", "regular");
- obj.attr("size", st.fileSize);
- if (st.isExecutable)
- obj.attr("executable", true);
- break;
- case FSAccessor::Type::tDirectory:
- obj.attr("type", "directory");
- {
- auto res2 = obj.object("entries");
- for (auto & name : narAccessor->readDirectory(path)) {
- auto res3 = res2.placeholder(name);
- recurse(path + "/" + name, res3);
- }
- }
- break;
- case FSAccessor::Type::tSymlink:
- obj.attr("type", "symlink");
- obj.attr("target", narAccessor->readLink(path));
- break;
- default:
- abort();
- }
- };
-
{
auto res = jsonRoot.placeholder("root");
- recurse("", res);
+ listNar(res, narAccessor, "");
}
}
diff --git a/src/libstore/nar-accessor.cc b/src/libstore/nar-accessor.cc
index 2afdeb021..b2d15c395 100644
--- a/src/libstore/nar-accessor.cc
+++ b/src/libstore/nar-accessor.cc
@@ -1,5 +1,6 @@
#include "nar-accessor.hh"
#include "archive.hh"
+#include "json.hh"
#include <map>
#include <stack>
@@ -181,4 +182,36 @@ ref<FSAccessor> makeNarAccessor(ref<const std::string> nar)
return make_ref<NarAccessor>(nar);
}
+void listNar(JSONPlaceholder & res, ref<FSAccessor> accessor, const Path & path)
+{
+ auto st = accessor->stat(path);
+
+ auto obj = res.object();
+
+ switch (st.type) {
+ case FSAccessor::Type::tRegular:
+ obj.attr("type", "regular");
+ obj.attr("size", st.fileSize);
+ if (st.isExecutable)
+ obj.attr("executable", true);
+ break;
+ case FSAccessor::Type::tDirectory:
+ obj.attr("type", "directory");
+ {
+ auto res2 = obj.object("entries");
+ for (auto & name : accessor->readDirectory(path)) {
+ auto res3 = res2.placeholder(name);
+ listNar(res3, accessor, path + "/" + name);
+ }
+ }
+ break;
+ case FSAccessor::Type::tSymlink:
+ obj.attr("type", "symlink");
+ obj.attr("target", accessor->readLink(path));
+ break;
+ default:
+ abort();
+ }
+}
+
}
diff --git a/src/libstore/nar-accessor.hh b/src/libstore/nar-accessor.hh
index 83c570be4..7699cbbb5 100644
--- a/src/libstore/nar-accessor.hh
+++ b/src/libstore/nar-accessor.hh
@@ -8,4 +8,8 @@ namespace nix {
file. */
ref<FSAccessor> makeNarAccessor(ref<const std::string> nar);
+class JSONPlaceholder;
+
+void listNar(JSONPlaceholder & res, ref<FSAccessor> accessor, const Path & path);
+
}