forked from lix-project/lix
Convert NIX_COUNT_CALLS to JSON too
This commit is contained in:
parent
0a2545f95c
commit
91405986f4
1 changed files with 41 additions and 35 deletions
|
@ -1728,7 +1728,6 @@ bool EvalState::eqValues(Value & v1, Value & v2)
|
||||||
void EvalState::printStats()
|
void EvalState::printStats()
|
||||||
{
|
{
|
||||||
bool showStats = getEnv("NIX_SHOW_STATS", "0") != "0";
|
bool showStats = getEnv("NIX_SHOW_STATS", "0") != "0";
|
||||||
Verbosity v = showStats ? lvlInfo : lvlDebug;
|
|
||||||
|
|
||||||
struct rusage buf;
|
struct rusage buf;
|
||||||
getrusage(RUSAGE_SELF, &buf);
|
getrusage(RUSAGE_SELF, &buf);
|
||||||
|
@ -1779,7 +1778,7 @@ void EvalState::printStats()
|
||||||
sets.attr("elements", nrAttrsInAttrsets);
|
sets.attr("elements", nrAttrsInAttrsets);
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
JSONObject sizes = topObj.object("sizes");
|
auto sizes = topObj.object("sizes");
|
||||||
sizes.attr("Env", sizeof(Env));
|
sizes.attr("Env", sizeof(Env));
|
||||||
sizes.attr("Value", sizeof(Value));
|
sizes.attr("Value", sizeof(Value));
|
||||||
sizes.attr("Bindings", sizeof(Bindings));
|
sizes.attr("Bindings", sizeof(Bindings));
|
||||||
|
@ -1793,40 +1792,47 @@ void EvalState::printStats()
|
||||||
topObj.attr("nrPrimOpCalls", nrPrimOpCalls);
|
topObj.attr("nrPrimOpCalls", nrPrimOpCalls);
|
||||||
topObj.attr("nrFunctionCalls", nrFunctionCalls);
|
topObj.attr("nrFunctionCalls", nrFunctionCalls);
|
||||||
#if HAVE_BOEHMGC
|
#if HAVE_BOEHMGC
|
||||||
JSONObject gc = topObj.object("gc");
|
{
|
||||||
|
auto gc = topObj.object("gc");
|
||||||
gc.attr("heapSize", heapSize);
|
gc.attr("heapSize", heapSize);
|
||||||
gc.attr("totalBytes", totalBytes);
|
gc.attr("totalBytes", totalBytes);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
if (countCalls) {
|
if (countCalls) {
|
||||||
v = lvlInfo;
|
{
|
||||||
|
auto obj = topObj.object("primops");
|
||||||
printMsg(v, format("calls to %1% primops:") % primOpCalls.size());
|
|
||||||
typedef std::multimap<size_t, Symbol> PrimOpCalls_;
|
|
||||||
PrimOpCalls_ primOpCalls_;
|
|
||||||
for (auto & i : primOpCalls)
|
for (auto & i : primOpCalls)
|
||||||
primOpCalls_.insert(std::pair<size_t, Symbol>(i.second, i.first));
|
obj.attr(i.first, i.second);
|
||||||
for (auto i = primOpCalls_.rbegin(); i != primOpCalls_.rend(); ++i)
|
}
|
||||||
printMsg(v, format("%1$10d %2%") % i->first % i->second);
|
{
|
||||||
|
auto list = topObj.list("functions");
|
||||||
printMsg(v, format("calls to %1% functions:") % functionCalls.size());
|
for (auto & i : functionCalls) {
|
||||||
typedef std::multimap<size_t, ExprLambda *> FunctionCalls_;
|
auto obj = list.object();
|
||||||
FunctionCalls_ functionCalls_;
|
if (i.first->name.set())
|
||||||
for (auto & i : functionCalls)
|
obj.attr("name", (const string &) i.first->name);
|
||||||
functionCalls_.insert(std::pair<size_t, ExprLambda *>(i.second, i.first));
|
else
|
||||||
for (auto i = functionCalls_.rbegin(); i != functionCalls_.rend(); ++i)
|
obj.attr("name", nullptr);
|
||||||
printMsg(v, format("%1$10d %2%") % i->first % i->second->showNamePos());
|
if (i.first->pos) {
|
||||||
|
obj.attr("file", (const string &) i.first->pos.file);
|
||||||
printMsg(v, format("evaluations of %1% attributes:") % attrSelects.size());
|
obj.attr("line", i.first->pos.line);
|
||||||
typedef std::multimap<size_t, Pos> AttrSelects_;
|
obj.attr("column", i.first->pos.column);
|
||||||
AttrSelects_ attrSelects_;
|
}
|
||||||
for (auto & i : attrSelects)
|
obj.attr("count", i.second);
|
||||||
attrSelects_.insert(std::pair<size_t, Pos>(i.second, i.first));
|
}
|
||||||
for (auto i = attrSelects_.rbegin(); i != attrSelects_.rend(); ++i)
|
}
|
||||||
printMsg(v, format("%1$10d %2%") % i->first % i->second);
|
{
|
||||||
|
auto list = topObj.list("attributes");
|
||||||
|
for (auto & i : attrSelects) {
|
||||||
|
auto obj = list.object();
|
||||||
|
if (i.first) {
|
||||||
|
obj.attr("file", (const string &) i.first.file);
|
||||||
|
obj.attr("line", i.first.line);
|
||||||
|
obj.attr("column", i.first.column);
|
||||||
|
}
|
||||||
|
obj.attr("count", i.second);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue