#pragma once #include "eval.hh" #include "path.hh" #include #include namespace nix { struct DrvInfo { public: typedef std::map> Outputs; private: EvalState * state; mutable std::string name; mutable std::string system; mutable std::optional> drvPath; mutable std::optional outPath; mutable std::string outputName; Outputs outputs; bool failed = false; // set if we get an AssertionError Bindings * attrs = nullptr, * meta = nullptr; Bindings * getMeta(); bool checkMeta(Value & v); public: std::string attrPath; /* path towards the derivation */ DrvInfo(EvalState & state) : state(&state) { }; DrvInfo(EvalState & state, std::string attrPath, Bindings * attrs); DrvInfo(EvalState & state, ref store, const std::string & drvPathWithOutputs); std::string queryName() const; std::string querySystem() const; std::optional queryDrvPath() const; StorePath requireDrvPath() const; StorePath queryOutPath() const; std::string queryOutputName() const; /** Return the unordered map of output names to (optional) output paths. * The "outputs to install" are determined by `meta.outputsToInstall`. */ Outputs queryOutputs(bool withPaths = true, bool onlyOutputsToInstall = false); StringSet queryMetaNames(); Value * queryMeta(const std::string & name); std::string queryMetaString(const std::string & name); NixInt queryMetaInt(const std::string & name, NixInt def); NixFloat queryMetaFloat(const std::string & name, NixFloat def); bool queryMetaBool(const std::string & name, bool def); void setMeta(const std::string & name, Value * v); /* MetaInfo queryMetaInfo(EvalState & state) const; MetaValue queryMetaInfo(EvalState & state, const string & name) const; */ void setName(const std::string & s) { name = s; } void setDrvPath(StorePath path) { drvPath = {{std::move(path)}}; } void setOutPath(StorePath path) { outPath = {{std::move(path)}}; } void setFailed() { failed = true; }; bool hasFailed() { return failed; }; }; #if HAVE_BOEHMGC typedef std::list> DrvInfos; #else typedef std::list DrvInfos; #endif /* If value `v' denotes a derivation, return a DrvInfo object describing it. Otherwise return nothing. */ std::optional getDerivation(EvalState & state, Value & v, bool ignoreAssertionFailures); void getDerivations(EvalState & state, Value & v, const std::string & pathPrefix, Bindings & autoArgs, DrvInfos & drvs, bool ignoreAssertionFailures); }