1 #include "apitracecall.h"
3 #include "trace_model.hpp"
8 ApiPointer::ApiPointer(int val)
13 QString ApiPointer::toString() const
16 return QString("0x%1").arg(m_value, 0, 16);
18 return QLatin1String("NULL");
21 QString apiVariantToString(const QVariant &variant)
23 if (variant.userType() == QVariant::Double) {
24 return QString::number(variant.toFloat());
26 if (variant.userType() == QVariant::ByteArray) {
27 if (variant.toByteArray().size() < 1024) {
28 int bytes = variant.toByteArray().size();
29 return QObject::tr("[binary data, size = %1 bytes]").arg(bytes);
31 float kb = variant.toByteArray().size()/1024.;
32 return QObject::tr("[binary data, size = %1 kb]").arg(kb);
36 if (variant.userType() < QVariant::UserType) {
37 return variant.toString();
40 if (variant.canConvert<ApiPointer>()) {
41 return variant.value<ApiPointer>().toString();
43 if (variant.canConvert<ApiBitmask>()) {
44 return variant.value<ApiBitmask>().toString();
46 if (variant.canConvert<ApiStruct>()) {
47 return variant.value<ApiStruct>().toString();
49 if (variant.canConvert<ApiArray>()) {
50 return variant.value<ApiArray>().toString();
56 ApiBitmask::ApiBitmask(const Trace::Bitmask *bitmask)
63 void ApiBitmask::init(const Trace::Bitmask *bitmask)
68 m_value = bitmask->value;
69 for (Trace::Bitmask::Signature::const_iterator it = bitmask->sig->begin();
70 it != bitmask->sig->end(); ++it) {
72 QPair<QString, unsigned long long> pair;
74 pair.first = QString::fromStdString(it->first);
75 pair.second = it->second;
81 QString ApiBitmask::toString() const
84 unsigned long long value = m_value;
86 for (Signature::const_iterator it = m_sig.begin();
87 value != 0 && it != m_sig.end(); ++it) {
89 if ((value & it->second) == it->second) {
91 str += QLatin1String(" | ");
100 str += QLatin1String(" | ");
102 str += QString::fromLatin1("0x%1").arg(value, 0, 16);
107 ApiStruct::ApiStruct(const Trace::Struct *s)
112 QString ApiStruct::toString() const
116 str += QLatin1String("{");
117 for (unsigned i = 0; i < m_members.count(); ++i) {
118 str += m_sig.memberNames[i];
119 str += QLatin1String(" = ");
120 str += apiVariantToString(m_members[i]);
121 if (i < m_members.count() - 1)
122 str += QLatin1String(", ");
124 str += QLatin1String("}");
129 void ApiStruct::init(const Trace::Struct *s)
134 m_sig.name = QString::fromStdString(s->sig->name);
135 for (unsigned i = 0; i < s->members.size(); ++i) {
137 m_sig.memberNames.append(
138 QString::fromStdString(s->sig->member_names[i]));
139 s->members[i]->visit(vis);
140 m_members.append(vis.variant());
144 void VariantVisitor::visit(Trace::Null *)
146 m_variant = QVariant(QLatin1String("NULL"));
149 void VariantVisitor::visit(Trace::Bool *node)
151 m_variant = QVariant(node->value);
154 void VariantVisitor::visit(Trace::SInt *node)
156 m_variant = QVariant(node->value);
159 void VariantVisitor::visit(Trace::UInt *node)
161 m_variant = QVariant(node->value);
164 void VariantVisitor::visit(Trace::Float *node)
166 m_variant = QVariant(node->value);
169 void VariantVisitor::visit(Trace::String *node)
171 m_variant = QVariant(QString::fromStdString(node->value));
174 void VariantVisitor::visit(Trace::Enum *e)
176 m_variant = QVariant(QString::fromStdString(e->sig->first));
179 void VariantVisitor::visit(Trace::Bitmask *bitmask)
181 m_variant = QVariant::fromValue(ApiBitmask(bitmask));
184 void VariantVisitor::visit(Trace::Struct *str)
186 m_variant = QVariant::fromValue(ApiStruct(str));
189 void VariantVisitor::visit(Trace::Array *array)
191 m_variant = QVariant::fromValue(ApiArray(array));
194 void VariantVisitor::visit(Trace::Blob *blob)
196 QByteArray barray = QByteArray::fromRawData(blob->buf, blob->size);
197 m_variant = QVariant(barray);
200 void VariantVisitor::visit(Trace::Pointer *ptr)
202 m_variant = QVariant::fromValue(ApiPointer(ptr->value));
205 ApiArray::ApiArray(const Trace::Array *arr)
210 QString ApiArray::toString() const
213 str += QLatin1String("[");
214 for(int i = 0; i < m_array.count(); ++i) {
215 const QVariant &var = m_array[i];
216 str += apiVariantToString(var);
217 if (i < m_array.count() - 1)
218 str += QLatin1String(", ");
220 str += QLatin1String("]");
225 void ApiArray::init(const Trace::Array *arr)
230 for (int i = 0; i < arr->values.size(); ++i) {
232 arr->values[i]->visit(vis);
234 m_array.append(vis.variant());
238 QStaticText ApiTraceCall::staticText() const
240 if (!m_staticText.text().isEmpty())
243 QString richText = QString::fromLatin1("<span style=\"font-weight:bold\">%1</span>(").arg(name);
244 for (int i = 0; i < argNames.count(); ++i) {
245 richText += QLatin1String("<span style=\"color:#0000ff\">");
246 QString argText = apiVariantToString(argValues[i]);
248 //if arguments are really long (e.g. shader text), cut them
250 if (argText.length() > 40) {
251 QString shortened = argText.mid(0, 40);
252 shortened[argText.length() - 5] = '.';
253 shortened[argText.length() - 4] = '.';
254 shortened[argText.length() - 3] = '.';
255 shortened[argText.length() - 2] = argText[argText.length() - 2];
256 shortened[argText.length() - 1] = argText[argText.length() - 1];
257 richText += shortened;
261 richText += QLatin1String("</span>");
262 if (i < argNames.count() - 1)
263 richText += QString::fromLatin1(", ");
265 richText += QLatin1String(")");
266 if (returnValue.isValid()) {
267 richText += QLatin1String(" = ");
268 richText += QLatin1String("<span style=\"color:#0000ff\">");
269 richText += apiVariantToString(returnValue);
270 richText += QLatin1String("</span>");
273 m_staticText.setText(richText);
275 opt.setWrapMode(QTextOption::NoWrap);
276 m_staticText.setTextOption(opt);
277 m_staticText.prepare();
282 QString ApiTraceCall::toHtml() const
284 if (!m_richText.isEmpty())
287 m_richText = QString::fromLatin1("%1) <span style=\"font-weight:bold\">%2</span>(")
290 for (int i = 0; i < argNames.count(); ++i) {
291 m_richText += argNames[i];
292 m_richText += QString::fromLatin1(" = ");
293 m_richText += QLatin1String("<span style=\"color:#0000ff\">");
294 m_richText += apiVariantToString(argValues[i]);
295 m_richText += QLatin1String("</span>");
296 if (i < argNames.count() - 1)
297 m_richText += QString::fromLatin1(", ");
299 m_richText += QLatin1String(")");
301 if (returnValue.isValid()) {
302 m_richText += QLatin1String(" = ");
303 m_richText += QLatin1String("<span style=\"color:#0000ff\">");
304 m_richText += apiVariantToString(returnValue);
305 m_richText += QLatin1String("</span>");
310 QString ApiTraceCall::filterText() const
312 if (!m_filterText.isEmpty())
316 for (int i = 0; i < argNames.count(); ++i) {
317 m_filterText += argNames[i];
318 m_filterText += QString::fromLatin1(" = ");
320 if (argValues[i].type() == QVariant::ByteArray) {
321 m_hasBinaryData = true;
322 m_binaryDataIndex = i;
324 m_filterText += apiVariantToString(argValues[i]);
325 if (i < argNames.count() - 1)
326 m_filterText += QString::fromLatin1(", ");
328 m_filterText += QLatin1String(")");
330 if (returnValue.isValid()) {
331 m_filterText += QLatin1String(" = ");
332 m_filterText += apiVariantToString(returnValue);
337 QStaticText ApiTraceFrame::staticText() const
339 if (!m_staticText.text().isEmpty())
343 QString::fromLatin1("<span style=\"font-weight:bold\">Frame %1</span>").arg(number);
345 m_staticText.setText(richText);
347 opt.setWrapMode(QTextOption::NoWrap);
348 m_staticText.setTextOption(opt);
349 m_staticText.prepare();
354 int ApiTraceCall::numChildren() const
359 int ApiTraceFrame::numChildren() const
361 return calls.count();
364 ApiTraceFrame::ApiTraceFrame()
365 : ApiTraceEvent(ApiTraceEvent::Frame)
369 ApiTraceCall::ApiTraceCall()
370 : ApiTraceEvent(ApiTraceEvent::Call),
371 m_hasBinaryData(false),
376 ApiTraceEvent::ApiTraceEvent()
377 : m_type(ApiTraceEvent::None)
381 ApiTraceEvent::ApiTraceEvent(Type t)
386 ApiTraceCall::~ApiTraceCall()
390 QVariantMap ApiTraceEvent::state() const
395 void ApiTraceEvent::setState(const QVariantMap &state)
400 bool ApiTraceCall::hasBinaryData() const
402 return m_hasBinaryData;
405 int ApiTraceCall::binaryDataIndex() const
407 return m_binaryDataIndex;