X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=common%2Ftrace_writer_model.cpp;h=4cf82f65242f79f2e76d023dbaee2f0d478a2cf3;hb=75af867d17044b6e3992e579c35915e35d2a7e78;hp=4aa350de0034d2d2f432b09fd119300405fe7bf6;hpb=b4a3d1495a5e92ba23bf463bcea34a6e75b55294;p=apitrace diff --git a/common/trace_writer_model.cpp b/common/trace_writer_model.cpp index 4aa350d..4cf82f6 100644 --- a/common/trace_writer_model.cpp +++ b/common/trace_writer_model.cpp @@ -60,12 +60,16 @@ public: writer.writeFloat(node->value); } + void visit(Double *node) { + writer.writeDouble(node->value); + } + void visit(String *node) { writer.writeString(node->value); } void visit(Enum *node) { - writer.writeEnum(node->sig); + writer.writeEnum(node->sig, node->value); } void visit(Bitmask *node) { @@ -93,15 +97,29 @@ public: } void visit(Pointer *node) { - writer.writeOpaque((const void *) (size_t) node->value); + writer.writePointer(node->value); + } + + void visit(Repr *node) { + writer.beginRepr(); + _visit(node->humanValue); + _visit(node->machineValue); + writer.endRepr(); } void visit(Call *call) { - unsigned call_no = writer.beginEnter(call->sig); + unsigned call_no = writer.beginEnter(call->sig, call->thread_id); + if (call->backtrace != NULL) { + writer.beginBacktrace(call->backtrace->size()); + for (unsigned i = 0; i < call->backtrace->size(); ++i) { + writer.writeStackFrame((*call->backtrace)[i]); + } + writer.endBacktrace(); + } for (unsigned i = 0; i < call->args.size(); ++i) { - if (call->args[i]) { + if (call->args[i].value) { writer.beginArg(i); - _visit(call->args[i]); + _visit(call->args[i].value); writer.endArg(); } }