From fedbe693b9c0f5ba57fae82e3191efe8a633aa09 Mon Sep 17 00:00:00 2001 From: Kane York Date: Sat, 12 Sep 2020 08:40:55 -0700 Subject: refactor(3p/tvix): make Value.primOp a std::shared_ptr Change-Id: I04cc42ae62d2ff71b07fde8e3710dcc9b4363a05 Reviewed-on: https://cl.tvl.fyi/c/depot/+/1973 Reviewed-by: glittershark Tested-by: BuildkiteCI --- third_party/nix/src/libexpr/eval.cc | 5 ++--- third_party/nix/src/libexpr/value.hh | 2 +- 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/third_party/nix/src/libexpr/eval.cc b/third_party/nix/src/libexpr/eval.cc index 2a0aba1a4c..e157418117 100644 --- a/third_party/nix/src/libexpr/eval.cc +++ b/third_party/nix/src/libexpr/eval.cc @@ -434,13 +434,12 @@ Value* EvalState::addPrimOp(const std::string& name, size_t arity, primOp(*this, noPos, nullptr, v); return addConstant(name, v); } - Value* v = allocValue(); std::string name2 = std::string(name, 0, 2) == "__" ? std::string(name, 2) : name; Symbol sym = symbols.Create(name2); - // Even though PrimOp doesn't need tracing, it needs to be collected. + Value* v = allocValue(); v->type = tPrimOp; - v->primOp = new PrimOp(primOp, arity, sym); + v->primOp = std::make_shared(primOp, arity, sym); staticBaseEnv.vars[symbols.Create(name)] = baseEnvDispl; baseEnv.values[baseEnvDispl++] = v; baseEnv.values[0]->attrs->push_back(Attr(sym, v)); diff --git a/third_party/nix/src/libexpr/value.hh b/third_party/nix/src/libexpr/value.hh index 980d9affbb..82021c77c4 100644 --- a/third_party/nix/src/libexpr/value.hh +++ b/third_party/nix/src/libexpr/value.hh @@ -100,7 +100,7 @@ struct Value { NixThunk thunk; NixApp app; // TODO(tazjin): "app"? NixLambda lambda; - PrimOp* primOp; + std::shared_ptr primOp; NixPrimOpApp primOpApp; NixFloat fpoint; }; -- cgit 1.4.1