This is the shared object equivalent of builtins.exec, or a plugins equivalent accessible from the Nix language. Either way, since we don't have builtins.exec or plugins any more, I think it makes sense to remove this builtin. This will also allow us to drop the allow-unsafe-native-code-during-evaluation option, which formerly controlled whether builtins.exec and builtins.importNative were enabled. Cc: Griffin Smith <grfn@gws.fyi> Cc: Profpatsch <mail@profpatsch.de> Change-Id: I8993a8a79d559c102647308a2684c089bbc06713 Reviewed-on: https://cl.tvl.fyi/c/depot/+/1340 Reviewed-by: glittershark <grfn@gws.fyi> Reviewed-by: Profpatsch <mail@profpatsch.de> Tested-by: BuildkiteCI
17 lines
498 B
C++
17 lines
498 B
C++
#include <tuple>
|
|
#include <vector>
|
|
|
|
#include "libexpr/eval.hh"
|
|
|
|
namespace nix {
|
|
|
|
struct RegisterPrimOp {
|
|
typedef std::vector<std::tuple<std::string, size_t, PrimOpFun>> PrimOps;
|
|
static PrimOps* primOps;
|
|
/* You can register a constant by passing an arity of 0. fun
|
|
will get called during EvalState initialization, so there
|
|
may be primops not yet added and builtins is not yet sorted. */
|
|
RegisterPrimOp(const std::string& name, size_t arity, PrimOpFun fun);
|
|
};
|
|
|
|
} // namespace nix
|