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 float kb = variant.toByteArray().size()/1024.;
28 return QObject::tr("[binary data, size = %1kb]").arg(kb);
31 if (variant.userType() < QVariant::UserType) {
32 return variant.toString();
35 if (variant.canConvert<ApiPointer>()) {
36 return variant.value<ApiPointer>().toString();
38 if (variant.canConvert<ApiBitmask>()) {
39 return variant.value<ApiBitmask>().toString();
41 if (variant.canConvert<ApiStruct>()) {
42 return variant.value<ApiStruct>().toString();
44 if (variant.canConvert<ApiArray>()) {
45 return variant.value<ApiArray>().toString();
51 ApiBitmask::ApiBitmask(const Trace::Bitmask *bitmask)
58 void ApiBitmask::init(const Trace::Bitmask *bitmask)
63 m_value = bitmask->value;
64 for (Trace::Bitmask::Signature::const_iterator it = bitmask->sig->begin();
65 it != bitmask->sig->end(); ++it) {
67 QPair<QString, unsigned long long> pair;
69 pair.first = QString::fromStdString(it->first);
70 pair.second = it->second;
76 QString ApiBitmask::toString() const
79 unsigned long long value = m_value;
81 for (Signature::const_iterator it = m_sig.begin();
82 value != 0 && it != m_sig.end(); ++it) {
84 if ((value & it->second) == it->second) {
86 str += QLatin1String(" | ");
95 str += QLatin1String(" | ");
97 str += QString::fromLatin1("0x%1").arg(value, 0, 16);
102 ApiStruct::ApiStruct(const Trace::Struct *s)
107 QString ApiStruct::toString() const
111 str += QLatin1String("{");
112 for (unsigned i = 0; i < m_members.count(); ++i) {
113 str += m_sig.memberNames[i];
114 str += QLatin1String(" = ");
115 str += apiVariantToString(m_members[i]);
116 if (i < m_members.count() - 1)
117 str += QLatin1String(", ");
119 str += QLatin1String("}");
124 void ApiStruct::init(const Trace::Struct *s)
129 m_sig.name = QString::fromStdString(s->sig->name);
130 for (unsigned i = 0; i < s->members.size(); ++i) {
132 m_sig.memberNames.append(
133 QString::fromStdString(s->sig->member_names[i]));
134 s->members[i]->visit(vis);
135 m_members.append(vis.variant());
139 void VariantVisitor::visit(Trace::Null *)
141 m_variant = QVariant(QLatin1String("NULL"));
144 void VariantVisitor::visit(Trace::Bool *node)
146 m_variant = QVariant(node->value);
149 void VariantVisitor::visit(Trace::SInt *node)
151 m_variant = QVariant(node->value);
154 void VariantVisitor::visit(Trace::UInt *node)
156 m_variant = QVariant(node->value);
159 void VariantVisitor::visit(Trace::Float *node)
161 m_variant = QVariant(node->value);
164 void VariantVisitor::visit(Trace::String *node)
166 m_variant = QVariant(QString::fromStdString(node->value));
169 void VariantVisitor::visit(Trace::Enum *e)
171 m_variant = QVariant(QString::fromStdString(e->sig->first));
174 void VariantVisitor::visit(Trace::Bitmask *bitmask)
176 m_variant = QVariant::fromValue(ApiBitmask(bitmask));
179 void VariantVisitor::visit(Trace::Struct *str)
181 m_variant = QVariant::fromValue(ApiStruct(str));
184 void VariantVisitor::visit(Trace::Array *array)
186 m_variant = QVariant::fromValue(ApiArray(array));
189 void VariantVisitor::visit(Trace::Blob *blob)
191 QByteArray barray = QByteArray::fromRawData(blob->buf, blob->size);
192 m_variant = QVariant(barray);
195 void VariantVisitor::visit(Trace::Pointer *ptr)
197 m_variant = QVariant::fromValue(ApiPointer(ptr->value));
200 ApiArray::ApiArray(const Trace::Array *arr)
205 QString ApiArray::toString() const
208 str += QLatin1String("[");
209 for(int i = 0; i < m_array.count(); ++i) {
210 const QVariant &var = m_array[i];
211 str += apiVariantToString(var);
212 if (i < m_array.count() - 1)
213 str += QLatin1String(", ");
215 str += QLatin1String("]");
220 void ApiArray::init(const Trace::Array *arr)
225 for (int i = 0; i < arr->values.size(); ++i) {
227 arr->values[i]->visit(vis);
229 m_array.append(vis.variant());
233 QStaticText ApiTraceCall::staticText() const
235 if (!m_staticText.text().isEmpty())
238 QString richText = QString::fromLatin1("<span style=\"font-weight:bold\">%1</span>(").arg(name);
239 for (int i = 0; i < argNames.count(); ++i) {
240 richText += QLatin1String("<span style=\"color:#0000ff\">");
241 QString argText = apiVariantToString(argValues[i]);
243 //if arguments are really long (e.g. shader text), cut them
245 if (argText.length() > 40) {
246 QString shortened = argText.mid(0, 40);
247 shortened[argText.length() - 5] = '.';
248 shortened[argText.length() - 4] = '.';
249 shortened[argText.length() - 3] = '.';
250 shortened[argText.length() - 2] = argText[argText.length() - 2];
251 shortened[argText.length() - 1] = argText[argText.length() - 1];
252 richText += shortened;
256 richText += QLatin1String("</span>");
257 if (i < argNames.count() - 1)
258 richText += QString::fromLatin1(", ");
260 richText += QLatin1String(")");
261 if (returnValue.isValid()) {
262 richText += QLatin1String(" = ");
263 richText += QLatin1String("<span style=\"color:#0000ff\">");
264 richText += apiVariantToString(returnValue);
265 richText += QLatin1String("</span>");
268 m_staticText.setText(richText);
270 opt.setWrapMode(QTextOption::NoWrap);
271 m_staticText.setTextOption(opt);
272 m_staticText.prepare();
277 QString ApiTraceCall::toHtml() const
279 if (!m_richText.isEmpty())
282 m_richText = QString::fromLatin1("<span style=\"font-weight:bold\">%1</span>(").arg(name);
283 for (int i = 0; i < argNames.count(); ++i) {
284 m_richText += argNames[i];
285 m_richText += QString::fromLatin1(" = ");
286 m_richText += QLatin1String("<span style=\"color:#0000ff\">");
287 m_richText += apiVariantToString(argValues[i]);
288 m_richText += QLatin1String("</span>");
289 if (i < argNames.count() - 1)
290 m_richText += QString::fromLatin1(", ");
292 m_richText += QLatin1String(")");
294 if (returnValue.isValid()) {
295 m_richText += QLatin1String(" = ");
296 m_richText += QLatin1String("<span style=\"color:#0000ff\">");
297 m_richText += apiVariantToString(returnValue);
298 m_richText += QLatin1String("</span>");
303 QString ApiTraceCall::filterText() const
305 if (!m_filterText.isEmpty())
309 for (int i = 0; i < argNames.count(); ++i) {
310 m_filterText += argNames[i];
311 m_filterText += QString::fromLatin1(" = ");
312 m_filterText += apiVariantToString(argValues[i]);
313 if (i < argNames.count() - 1)
314 m_filterText += QString::fromLatin1(", ");
316 m_filterText += QLatin1String(")");
318 if (returnValue.isValid()) {
319 m_filterText += QLatin1String(" = ");
320 m_filterText += apiVariantToString(returnValue);
325 QStaticText ApiTraceFrame::staticText() const
327 if (!m_staticText.text().isEmpty())
331 QString::fromLatin1("<span style=\"font-weight:bold\">Frame %1</span>").arg(number);
333 m_staticText.setText(richText);
335 opt.setWrapMode(QTextOption::NoWrap);
336 m_staticText.setTextOption(opt);
337 m_staticText.prepare();
342 int ApiTraceCall::numChildren() const
347 int ApiTraceFrame::numChildren() const
349 return calls.count();
352 ApiTraceFrame::ApiTraceFrame()
353 : ApiTraceEvent(ApiTraceEvent::Frame)
357 ApiTraceCall::ApiTraceCall()
358 : ApiTraceEvent(ApiTraceEvent::Call)
362 ApiTraceEvent::ApiTraceEvent()
363 : m_type(ApiTraceEvent::None)
367 ApiTraceEvent::ApiTraceEvent(Type t)
372 ApiTraceCall::~ApiTraceCall()
376 QVariantMap ApiTraceEvent::state() const
381 void ApiTraceEvent::setState(const QVariantMap &state)