2016-02-25 18:43:19 +02:00
|
|
|
#pragma once
|
2023-04-01 06:18:41 +03:00
|
|
|
///@file
|
2016-02-25 18:43:19 +02:00
|
|
|
|
2023-11-01 18:09:28 +02:00
|
|
|
#include "source-accessor.hh"
|
|
|
|
|
2017-12-16 01:48:09 +02:00
|
|
|
#include <functional>
|
|
|
|
|
2022-11-16 17:49:49 +02:00
|
|
|
#include <nlohmann/json_fwd.hpp>
|
2016-02-25 18:43:19 +02:00
|
|
|
|
|
|
|
namespace nix {
|
|
|
|
|
2020-07-13 18:30:42 +03:00
|
|
|
struct Source;
|
|
|
|
|
2023-04-07 16:55:28 +03:00
|
|
|
/**
|
|
|
|
* Return an object that provides access to the contents of a NAR
|
|
|
|
* file.
|
|
|
|
*/
|
2023-11-01 18:09:28 +02:00
|
|
|
ref<SourceAccessor> makeNarAccessor(std::string && nar);
|
2016-02-25 18:43:19 +02:00
|
|
|
|
2023-11-01 18:09:28 +02:00
|
|
|
ref<SourceAccessor> makeNarAccessor(Source & source);
|
2020-07-13 18:30:42 +03:00
|
|
|
|
2023-04-07 16:55:28 +03: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.
|
|
|
|
*/
|
2023-11-07 14:40:21 +02:00
|
|
|
using GetNarBytes = std::function<std::string(uint64_t, uint64_t)>;
|
2017-12-07 01:50:46 +02:00
|
|
|
|
2023-11-01 18:09:28 +02:00
|
|
|
ref<SourceAccessor> makeLazyNarAccessor(
|
2017-12-07 01:50:46 +02:00
|
|
|
const std::string & listing,
|
|
|
|
GetNarBytes getNarBytes);
|
|
|
|
|
2023-04-07 16:55:28 +03:00
|
|
|
/**
|
|
|
|
* Write a JSON representation of the contents of a NAR (except file
|
|
|
|
* contents).
|
|
|
|
*/
|
2023-11-01 18:09:28 +02:00
|
|
|
nlohmann::json listNar(ref<SourceAccessor> accessor, const CanonPath & path, bool recurse);
|
2017-11-14 15:23:53 +02:00
|
|
|
|
2016-02-25 18:43:19 +02:00
|
|
|
}
|