X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=gui%2Fapitracecall.cpp;h=907e10aa08294fc878549708a92e074fc9eb2681;hb=e7d7a643767ab46fdc15b4d7f430c38064f8e9ce;hp=dfaaeef0e478a6a7b7a9fba76b02ec510a67bcba;hpb=8759ae0a429088d4d1e54b6c0c205e8058150245;p=apitrace diff --git a/gui/apitracecall.cpp b/gui/apitracecall.cpp index dfaaeef..907e10a 100644 --- a/gui/apitracecall.cpp +++ b/gui/apitracecall.cpp @@ -227,6 +227,12 @@ void VariantVisitor::visit(trace::Pointer *ptr) m_variant = QVariant::fromValue(ApiPointer(ptr->value)); } +void VariantVisitor::visit(trace::Repr *repr) +{ + /* TODO: Preserve both the human and machine value */ + repr->humanValue->visit(*this); +} + ApiTraceEnumSignature::ApiTraceEnumSignature(const trace::EnumSig *sig) { for (const trace::EnumValue *it = sig->values; @@ -336,7 +342,6 @@ void ApiBitmask::init(const trace::Bitmask *bitmask) m_value = bitmask->value; for (const trace::BitmaskFlag *it = bitmask->sig->flags; it != bitmask->sig->flags + bitmask->sig->num_flags; ++it) { - assert(it->value); QPair pair; pair.first = QString::fromStdString(it->name); @@ -351,10 +356,10 @@ QString ApiBitmask::toString() const QString str; unsigned long long value = m_value; bool first = true; - for (Signature::const_iterator it = m_sig.begin(); - value != 0 && it != m_sig.end(); ++it) { - Q_ASSERT(it->second); - if ((value & it->second) == it->second) { + for (Signature::const_iterator it = m_sig.begin(); it != m_sig.end(); ++it) { + Q_ASSERT(it->second || first); + if ((it->second && (value & it->second) == it->second) || + (!it->second && value == 0)) { if (!first) { str += QLatin1String(" | "); } @@ -362,6 +367,9 @@ QString ApiBitmask::toString() const value &= ~it->second; first = false; } + if (value == 0) { + break; + } } if (value || first) { if (!first) {