nix-super/src/libexpr/flake/flakeref.hh

62 lines
1.6 KiB
C++
Raw Normal View History

#pragma once
2019-02-12 19:23:11 +02:00
#include "types.hh"
#include "hash.hh"
#include "fetchers/fetchers.hh"
2019-02-12 19:23:11 +02:00
#include <variant>
namespace nix {
class Store;
2019-02-12 19:23:11 +02:00
typedef std::string FlakeId;
struct FlakeRef
{
std::shared_ptr<const fetchers::Input> input;
2019-02-12 19:23:11 +02:00
Path subdir;
2019-02-12 19:23:11 +02:00
bool operator==(const FlakeRef & other) const;
2019-04-08 20:03:00 +03:00
FlakeRef(const std::shared_ptr<const fetchers::Input> & input, const Path & subdir)
: input(input), subdir(subdir)
2019-04-08 20:03:00 +03:00
{
assert(input);
2019-04-08 20:03:00 +03:00
}
2019-02-12 19:23:11 +02:00
// FIXME: change to operator <<.
std::string to_string() const;
fetchers::Input::Attrs toAttrs() const;
2019-02-12 19:23:11 +02:00
/* Check whether this is a "direct" flake reference, that is, not
a flake ID, which requires a lookup in the flake registry. */
bool isDirect() const;
2019-02-12 19:23:11 +02:00
/* Check whether this is an "immutable" flake reference, that is,
one that contains a commit hash or content hash. */
bool isImmutable() const;
2019-02-12 19:23:11 +02:00
FlakeRef resolve(ref<Store> store) const;
static FlakeRef fromAttrs(const fetchers::Input::Attrs & attrs);
2019-03-10 08:05:05 +02:00
};
std::ostream & operator << (std::ostream & str, const FlakeRef & flakeRef);
FlakeRef parseFlakeRef(
const std::string & url, const std::optional<Path> & baseDir = {});
std::optional<FlakeRef> maybeParseFlake(
const std::string & url, const std::optional<Path> & baseDir = {});
std::pair<FlakeRef, std::string> parseFlakeRefWithFragment(
const std::string & url, const std::optional<Path> & baseDir = {});
std::optional<std::pair<FlakeRef, std::string>> maybeParseFlakeRefWithFragment(
const std::string & url, const std::optional<Path> & baseDir = {});
2019-02-12 19:23:11 +02:00
}