2021-10-25 16:53:01 +03:00
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include "comparator.hh"
|
|
|
|
|
#include "error.hh"
|
|
|
|
|
#include "nlohmann/json_fwd.hpp"
|
|
|
|
|
#include "types.hh"
|
|
|
|
|
|
|
|
|
|
namespace nix {
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* The list of available experimental features.
|
|
|
|
|
*
|
|
|
|
|
* If you update this, don’t forget to also change the map defining their
|
|
|
|
|
* string representation in the corresponding `.cc` file.
|
|
|
|
|
**/
|
|
|
|
|
enum struct ExperimentalFeature
|
|
|
|
|
{
|
|
|
|
|
CaDerivations,
|
2022-03-30 17:31:01 +03:00
|
|
|
|
ImpureDerivations,
|
2021-10-25 16:53:01 +03:00
|
|
|
|
Flakes,
|
|
|
|
|
NixCommand,
|
|
|
|
|
RecursiveNix,
|
2022-03-01 01:54:20 +02:00
|
|
|
|
NoUrlLiterals,
|
2022-03-24 22:33:20 +02:00
|
|
|
|
FetchClosure,
|
2022-05-20 15:20:00 +03:00
|
|
|
|
ReplFlake,
|
2022-03-01 01:54:20 +02:00
|
|
|
|
AutoAllocateUids,
|
2022-11-18 11:39:28 +02:00
|
|
|
|
Cgroups,
|
2021-10-25 16:53:01 +03:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Just because writing `ExperimentalFeature::CaDerivations` is way too long
|
|
|
|
|
*/
|
|
|
|
|
using Xp = ExperimentalFeature;
|
|
|
|
|
|
|
|
|
|
const std::optional<ExperimentalFeature> parseExperimentalFeature(
|
|
|
|
|
const std::string_view & name);
|
|
|
|
|
std::string_view showExperimentalFeature(const ExperimentalFeature);
|
|
|
|
|
|
|
|
|
|
std::ostream & operator<<(
|
|
|
|
|
std::ostream & str,
|
|
|
|
|
const ExperimentalFeature & feature);
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Parse a set of strings to the corresponding set of experimental features,
|
|
|
|
|
* ignoring (but warning for) any unkwown feature.
|
|
|
|
|
*/
|
|
|
|
|
std::set<ExperimentalFeature> parseFeatures(const std::set<std::string> &);
|
|
|
|
|
|
|
|
|
|
class MissingExperimentalFeature : public Error
|
|
|
|
|
{
|
|
|
|
|
public:
|
|
|
|
|
ExperimentalFeature missingFeature;
|
|
|
|
|
|
|
|
|
|
MissingExperimentalFeature(ExperimentalFeature);
|
|
|
|
|
};
|
|
|
|
|
|
2022-04-20 16:41:01 +03:00
|
|
|
|
/**
|
|
|
|
|
* Semi-magic conversion to and from json.
|
|
|
|
|
* See the nlohmann/json readme for more details.
|
|
|
|
|
*/
|
2022-05-03 15:37:28 +03:00
|
|
|
|
void to_json(nlohmann::json &, const ExperimentalFeature &);
|
|
|
|
|
void from_json(const nlohmann::json &, ExperimentalFeature &);
|
2022-04-20 16:41:01 +03:00
|
|
|
|
|
2021-10-25 16:53:01 +03:00
|
|
|
|
}
|