nix-super/src/libstore/content-address.hh

138 lines
3.3 KiB
C++
Raw Normal View History

2020-06-02 00:32:27 +03:00
#pragma once
2020-06-02 01:53:31 +03:00
#include <variant>
2020-06-02 00:32:27 +03:00
#include "hash.hh"
2020-10-07 16:52:20 +03:00
#include "path.hh"
#include "comparator.hh"
2020-06-02 00:32:27 +03:00
namespace nix {
2020-10-07 16:52:20 +03:00
/*
* Content addressing method
2020-10-07 16:52:20 +03:00
*/
2022-04-20 01:25:21 +03:00
/* We only have one way to hash text with references, so this is a single-value
type, mainly useful with std::variant.
*/
struct TextHashMethod : std::monostate { };
2020-06-02 00:32:27 +03:00
enum struct FileIngestionMethod : uint8_t {
Flat = false,
Recursive = true
};
struct FixedOutputHashMethod {
FileIngestionMethod fileIngestionMethod;
HashType hashType;
};
/* Compute the prefix to the hash algorithm which indicates how the files were
ingested. */
2022-04-20 01:25:21 +03:00
std::string makeFileIngestionPrefix(FileIngestionMethod m);
2022-04-20 01:25:21 +03:00
/* Just the type of a content address. Combine with the hash itself, and we
have a `ContentAddress` as defined below. Combine that, in turn, with info
on references, and we have `ContentAddressWithReferences`, as defined
further below. */
typedef std::variant<
TextHashMethod,
FixedOutputHashMethod
2023-01-06 18:18:14 +02:00
> ContentAddressMethod;
ContentAddressMethod parseContentAddressMethod(std::string_view rawCaMethod);
std::string renderContentAddressMethod(ContentAddressMethod caMethod);
/*
* Mini content address
*/
2020-10-07 16:52:20 +03:00
2020-06-02 02:26:40 +03:00
struct TextHash {
Hash hash;
GENERATE_CMP(TextHash, me->hash);
2020-06-02 02:26:40 +03:00
};
2020-06-02 00:32:27 +03:00
/// Pair of a hash, and how the file system was ingested
struct FixedOutputHash {
2020-06-02 00:32:27 +03:00
FileIngestionMethod method;
Hash hash;
std::string printMethodAlgo() const;
GENERATE_CMP(FixedOutputHash, me->method, me->hash);
2020-06-02 00:32:27 +03:00
};
2020-06-02 01:53:31 +03:00
/*
We've accumulated several types of content-addressed paths over the years;
fixed-output derivations support multiple hash algorithms and serialisation
methods (flat file vs NAR). Thus, ca has one of the following forms:
* text:sha256:<sha256 hash of file contents>: For paths
computed by makeTextPath() / addTextToStore().
* fixed:<r?>:<ht>:<h>: For paths computed by
makeFixedOutputPath() / addToStore().
*/
typedef std::variant<
2020-06-02 02:26:40 +03:00
TextHash, // for paths computed by makeTextPath() / addTextToStore
FixedOutputHash // for path computed by makeFixedOutputPath
2020-06-02 01:53:31 +03:00
> ContentAddress;
2020-06-02 02:26:40 +03:00
std::string renderContentAddress(ContentAddress ca);
std::string renderContentAddress(std::optional<ContentAddress> ca);
ContentAddress parseContentAddress(std::string_view rawCa);
2020-06-02 03:37:43 +03:00
std::optional<ContentAddress> parseContentAddressOpt(std::string_view rawCaOpt);
2020-06-02 03:37:43 +03:00
Hash getContentAddressHash(const ContentAddress & ca);
2022-04-20 01:25:21 +03:00
2020-10-07 16:52:20 +03:00
/*
* References set
*/
struct StoreReferences {
StorePathSet others;
bool self = false;
bool empty() const;
size_t size() const;
GENERATE_CMP(StoreReferences, me->self, me->others);
};
2020-10-07 16:52:20 +03:00
/*
* Full content address
*
* See the schema for store paths in store-api.cc
*/
// This matches the additional info that we need for makeTextPath
struct TextInfo {
TextHash hash;
2020-10-07 16:52:20 +03:00
// References for the paths, self references disallowed
StorePathSet references;
GENERATE_CMP(TextInfo, me->hash, me->references);
2020-10-07 16:52:20 +03:00
};
struct FixedOutputInfo {
FixedOutputHash hash;
2020-10-07 16:52:20 +03:00
// References for the paths
StoreReferences references;
GENERATE_CMP(FixedOutputInfo, me->hash, me->references);
2020-10-07 16:52:20 +03:00
};
typedef std::variant<
TextInfo,
FixedOutputInfo
> ContentAddressWithReferences;
ContentAddressWithReferences caWithoutRefs(const ContentAddress &);
2020-06-02 00:32:27 +03:00
}