diff options
author | Eelco Dolstra <edolstra@gmail.com> | 2019-08-15T12·20+0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-08-15T12·20+0200 |
commit | 477f82e5a7d1a69777cb55e14bb377adeb4bedd1 (patch) | |
tree | 8055789fcbb639a3197938682be49e9476cdf217 /src/libexpr/eval.cc | |
parent | 35ebae198f5af5b5283bfb36ef6e85a29006e4c9 (diff) | |
parent | ee9c988a1b2e3c511b8613e698a0f9632ab1538f (diff) |
Merge pull request #2782 from grahamc/flames
Track function start and end
Diffstat (limited to 'src/libexpr/eval.cc')
-rw-r--r-- | src/libexpr/eval.cc | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/src/libexpr/eval.cc b/src/libexpr/eval.cc index d8e10d9f20e1..9f4b6b411a72 100644 --- a/src/libexpr/eval.cc +++ b/src/libexpr/eval.cc @@ -9,6 +9,7 @@ #include "json.hh" #include <algorithm> +#include <chrono> #include <cstring> #include <unistd.h> #include <sys/time.h> @@ -16,7 +17,6 @@ #include <iostream> #include <fstream> -#include <sys/time.h> #include <sys/resource.h> #if HAVE_BOEHMGC @@ -1094,9 +1094,13 @@ void EvalState::callPrimOp(Value & fun, Value & arg, Value & v, const Pos & pos) } } - void EvalState::callFunction(Value & fun, Value & arg, Value & v, const Pos & pos) { + std::optional<FunctionCallTrace> trace; + if (evalSettings.traceFunctionCalls) { + trace.emplace(pos); + } + forceValue(fun, pos); if (fun.type == tPrimOp || fun.type == tPrimOpApp) { |