X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=gui%2Fapitracecall.h;h=3da1d7d169f8630bfd979bd638ccdf41515c9af1;hb=4d0ef5d3d040704f61e0814c9260c1a2ca11c24d;hp=4cfa9ae0b9bfd731d616a93fb7e5b00083042c83;hpb=96130aca85f0d828cae3da84dc9a7e258cbeb22a;p=apitrace diff --git a/gui/apitracecall.h b/gui/apitracecall.h index 4cfa9ae..3da1d7d 100644 --- a/gui/apitracecall.h +++ b/gui/apitracecall.h @@ -1,16 +1,24 @@ #ifndef APITRACECALL_H #define APITRACECALL_H +#include "apisurface.h" + #include #include +#include #include #include "trace_model.hpp" +class ApiTrace; + class VariantVisitor : public Trace::Visitor { public: + VariantVisitor(ApiTrace *trace) + : m_trace(trace) + {} virtual void visit(Trace::Null *); virtual void visit(Trace::Bool *node); virtual void visit(Trace::SInt *node); @@ -29,18 +37,51 @@ public: return m_variant; } private: + ApiTrace *m_trace; QVariant m_variant; }; +class ApiTraceEnumSignature +{ +public: + ApiTraceEnumSignature(const QString &name = QString(), + const QVariant &val=QVariant())\ + : m_name(name), + m_value(val) + {} + + QVariant value() const { return m_value; } + QString name() const { return m_name; } +private: + QString m_name; + QVariant m_value; +}; + +class ApiEnum +{ +public: + ApiEnum(ApiTraceEnumSignature *sig=0); + + QString toString() const; + + QVariant value() const; + QString name() const; +private: + ApiTraceEnumSignature *m_sig; +}; +Q_DECLARE_METATYPE(ApiEnum); class ApiPointer { public: - ApiPointer(int val=0); + ApiPointer(unsigned long long val=0); QString toString() const; + + unsigned long long value() const; + private: - int m_value; + unsigned long long m_value; }; Q_DECLARE_METATYPE(ApiPointer); @@ -53,6 +94,9 @@ public: QString toString() const; + unsigned long long value() const; + Signature signature() const; + private: void init(const Trace::Bitmask *bitmask); private: @@ -72,6 +116,8 @@ public: ApiStruct(const Trace::Struct *s = 0); QString toString() const; + Signature signature() const; + QList values() const; private: void init(const Trace::Struct *bitmask); @@ -85,9 +131,11 @@ class ApiArray { public: ApiArray(const Trace::Array *arr = 0); + ApiArray(const QList &vals); QString toString() const; + QList values() const; private: void init(const Trace::Array *arr); private: @@ -96,23 +144,170 @@ private: Q_DECLARE_METATYPE(ApiArray); -QString apiVariantToString(const QVariant &variant); +QString apiVariantToString(const QVariant &variant, bool multiLine = false); + +class ApiTraceFrame; + +class ApiTraceState { +public: + ApiTraceState(); + explicit ApiTraceState(const QVariantMap &parseJson); + + bool isEmpty() const; + const QVariantMap & parameters() const; + const QMap & shaderSources() const; + const QVariantMap & uniforms() const; + const QList & textures() const; + const QList & framebuffers() const; -class ApiTraceCall +private: + QVariantMap m_parameters; + QMap m_shaderSources; + QVariantMap m_uniforms; + QList m_textures; + QList m_framebuffers; +}; +Q_DECLARE_METATYPE(ApiTraceState); + +class ApiTraceCallSignature { public: - QString name; - QStringList argNames; - QVariantList argValues; - QVariant returnValue; + ApiTraceCallSignature(const QString &name, + const QStringList &argNames); + ~ApiTraceCallSignature(); + + QString name() const + { + return m_name; + } + QStringList argNames() const + { + return m_argNames; + } + + QUrl helpUrl() const; + void setHelpUrl(const QUrl &url); - QString richText() const; +private: + QString m_name; + QStringList m_argNames; + QUrl m_helpUrl; +}; + +class ApiTraceEvent +{ +public: + enum Type { + None = 0, + Call = 1 << 0, + Frame = 1 << 1 + }; +public: + ApiTraceEvent(); + ApiTraceEvent(Type t); + virtual ~ApiTraceEvent(); + + Type type() const { return (Type)m_type; } + + virtual QStaticText staticText() const = 0; + virtual int numChildren() const = 0; + + QVariantMap stateParameters() const; + ApiTraceState *state() const; + void setState(ApiTraceState *state); + bool hasState() const + { + return m_state && !m_state->isEmpty(); + } + +protected: + int m_type : 4; + mutable bool m_hasBinaryData; + mutable int m_binaryDataIndex:8; + ApiTraceState *m_state; + + mutable QStaticText *m_staticText; +}; +Q_DECLARE_METATYPE(ApiTraceEvent*); + +class ApiTraceCall : public ApiTraceEvent +{ +public: + ApiTraceCall(ApiTraceFrame *parentFrame, const Trace::Call *tcall); + ~ApiTraceCall(); + + int index() const; + QString name() const; + QStringList argNames() const; + QVariantList arguments() const; + QVariant returnValue() const; + QUrl helpUrl() const; + void setHelpUrl(const QUrl &url); + ApiTraceFrame *parentFrame()const; + void setParentFrame(ApiTraceFrame *frame); + + bool hasError() const; + QString error() const; + void setError(const QString &msg); + + QVariantList originalValues() const; + + bool edited() const; + void setEditedValues(const QVariantList &lst); + QVariantList editedValues() const; + void revert(); + + ApiTrace *parentTrace() const; + + QString toHtml() const; + QString searchText() const; QStaticText staticText() const; + int numChildren() const; + bool hasBinaryData() const; + int binaryDataIndex() const; private: + int m_index; + ApiTraceCallSignature *m_signature; + QVariantList m_argValues; + QVariant m_returnValue; + ApiTraceFrame *m_parentFrame; + + QVariantList m_editedValues; + + QString m_error; + mutable QString m_richText; - mutable QStaticText m_staticText; + mutable QString m_searchText; }; -Q_DECLARE_METATYPE(ApiTraceCall); Q_DECLARE_METATYPE(ApiTraceCall*); +class ApiTraceFrame : public ApiTraceEvent +{ +public: + ApiTraceFrame(ApiTrace *parent); + int number; + + bool isEmpty() const; + + ApiTrace *parentTrace() const; + + int numChildren() const; + QStaticText staticText() const; + + int callIndex(ApiTraceCall *call) const; + ApiTraceCall *call(int idx) const; + void addCall(ApiTraceCall *call); + QVector calls() const; + void setCalls(const QVector &calls, + quint64 binaryDataSize); + + int binaryDataSize() const; +private: + ApiTrace *m_parentTrace; + quint64 m_binaryDataSize; + QVector m_calls; +}; +Q_DECLARE_METATYPE(ApiTraceFrame*); + + #endif