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

99 lines
2.8 KiB
C++
Raw Normal View History

#pragma once
///@file
2019-02-12 19:23:11 +02:00
#include "types.hh"
#include "hash.hh"
#include "fetchers.hh"
#include "outputs-spec.hh"
2019-02-12 19:23:11 +02:00
#include <regex>
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;
/**
* A flake reference specifies how to fetch a flake or raw source
* (e.g. from a Git repository). It is created from a URL-like syntax
* (e.g. 'github:NixOS/patchelf'), an attrset representation (e.g. '{
* type="github"; owner = "NixOS"; repo = "patchelf"; }'), or a local
* path.
*
* Each flake will have a number of FlakeRef objects: one for each
* input to the flake.
*
* The normal method of constructing a FlakeRef is by starting with an
* input description (usually the attrs or a url from the flake file),
* locating a fetcher for that input, and then capturing the Input
* object that fetcher generates (usually via
* FlakeRef::fromAttrs(attrs) or parseFlakeRef(url) calls).
*
2022-08-04 10:45:28 +03:00
* The actual fetch may not have been performed yet (i.e. a FlakeRef may
* be lazy), but the fetcher can be invoked at any time via the
* FlakeRef to ensure the store is populated with this input.
*/
2019-02-12 19:23:11 +02:00
struct FlakeRef
{
/**
* Fetcher-specific representation of the input, sufficient to
* perform the fetch operation.
*/
fetchers::Input input;
2019-02-12 19:23:11 +02:00
/**
* sub-path within the fetched input that represents this input
*/
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(fetchers::Input && input, const Path & subdir)
: input(std::move(input)), subdir(subdir)
{ }
2019-02-12 19:23:11 +02:00
// FIXME: change to operator <<.
std::string to_string() const;
2020-03-17 21:54:36 +02:00
fetchers::Attrs toAttrs() const;
FlakeRef resolve(ref<Store> store) const;
2020-03-17 21:54:36 +02:00
static FlakeRef fromAttrs(const fetchers::Attrs & attrs);
2020-02-02 12:31:58 +02:00
std::pair<fetchers::Tree, FlakeRef> fetchTree(ref<Store> store) const;
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 = {},
bool allowMissing = false,
bool isFlake = true);
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 = {},
bool allowMissing = false,
bool isFlake = true);
std::optional<std::pair<FlakeRef, std::string>> maybeParseFlakeRefWithFragment(
const std::string & url, const std::optional<Path> & baseDir = {});
std::tuple<FlakeRef, std::string, ExtendedOutputsSpec> parseFlakeRefWithFragmentAndExtendedOutputsSpec(
const std::string & url,
const std::optional<Path> & baseDir = {},
bool allowMissing = false,
bool isFlake = true);
const static std::string flakeIdRegexS = "[a-zA-Z][a-zA-Z0-9_-]*";
extern std::regex flakeIdRegex;
2019-02-12 19:23:11 +02:00
}