2016-02-25 17:43:19 +01:00
|
|
|
#pragma once
|
|
|
|
|
2017-12-16 00:48:09 +01:00
|
|
|
#include <functional>
|
|
|
|
|
2016-02-25 17:43:19 +01:00
|
|
|
#include "fs-accessor.hh"
|
|
|
|
|
|
|
|
namespace nix {
|
|
|
|
|
|
|
|
/* Return an object that provides access to the contents of a NAR
|
|
|
|
file. */
|
|
|
|
ref<FSAccessor> makeNarAccessor(ref<const std::string> nar);
|
|
|
|
|
2017-12-07 00:50:46 +01:00
|
|
|
/* Create a NAR accessor from a NAR listing (in the format produced by
|
|
|
|
listNar()). The callback getNarBytes(offset, length) is used by the
|
|
|
|
readFile() method of the accessor to get the contents of files
|
|
|
|
inside the NAR. */
|
|
|
|
typedef std::function<std::string(uint64_t, uint64_t)> GetNarBytes;
|
|
|
|
|
|
|
|
ref<FSAccessor> makeLazyNarAccessor(
|
|
|
|
const std::string & listing,
|
|
|
|
GetNarBytes getNarBytes);
|
|
|
|
|
2017-11-14 14:23:53 +01:00
|
|
|
class JSONPlaceholder;
|
|
|
|
|
2017-11-14 14:31:28 +01:00
|
|
|
/* Write a JSON representation of the contents of a NAR (except file
|
|
|
|
contents). */
|
|
|
|
void listNar(JSONPlaceholder & res, ref<FSAccessor> accessor,
|
|
|
|
const Path & path, bool recurse);
|
2017-11-14 14:23:53 +01:00
|
|
|
|
2016-02-25 17:43:19 +01:00
|
|
|
}
|