lix/src/libexpr/primops/flake.hh

73 lines
1.5 KiB
C++
Raw Normal View History

2019-02-12 17:23:11 +00:00
#include "types.hh"
#include "flakeref.hh"
#include <variant>
namespace nix {
struct Value;
class EvalState;
2019-02-12 17:23:11 +00:00
struct FlakeRegistry
{
struct Entry
{
FlakeRef ref;
Entry(const FlakeRef & flakeRef) : ref(flakeRef) {};
2019-03-10 06:05:05 +00:00
Entry operator=(const Entry & entry) { return Entry(entry.ref); }
2019-02-12 17:23:11 +00:00
};
std::map<FlakeId, Entry> entries;
};
2019-03-10 06:05:05 +00:00
Path getUserRegistryPath();
Value * makeFlakeRegistryValue(EvalState & state);
Value * makeFlakeValue(EvalState & state, const FlakeRef & flakeRef, bool impureTopRef, Value & v);
2019-03-21 08:30:16 +00:00
std::shared_ptr<FlakeRegistry> readRegistry(const Path &);
2019-03-10 06:05:05 +00:00
void writeRegistry(FlakeRegistry, Path);
2019-02-21 05:53:01 +00:00
struct Flake
{
FlakeId id;
FlakeRef ref;
2019-02-21 05:53:01 +00:00
std::string description;
Path path;
std::optional<uint64_t> revCount;
2019-02-21 05:53:01 +00:00
std::vector<FlakeRef> requires;
2019-03-21 08:30:16 +00:00
std::shared_ptr<FlakeRegistry> lockFile;
std::map<FlakeId, FlakeRef> nonFlakeRequires;
2019-02-21 05:53:01 +00:00
Value * vProvides; // FIXME: gc
// date
// content hash
Flake(const FlakeRef flakeRef) : ref(flakeRef) {};
};
struct NonFlake
{
FlakeId id;
FlakeRef ref;
Path path;
// date
// content hash
NonFlake(const FlakeRef flakeRef) : ref(flakeRef) {};
2019-02-21 05:53:01 +00:00
};
Flake getFlake(EvalState &, const FlakeRef &);
struct Dependencies
{
FlakeId topFlakeId;
std::vector<Flake> flakes;
std::vector<NonFlake> nonFlakes;
};
Dependencies resolveFlake(EvalState &, const FlakeRef &, bool impureTopRef);
FlakeRegistry updateLockFile(EvalState &, Flake &);
2019-02-25 12:46:37 +00:00
void updateLockFile(EvalState &, std::string);
2019-02-12 17:23:11 +00:00
}