X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=gui%2Fapitracecall.h;h=12b0216a6e6ee4763da8d915d4cabbbb12b42858;hb=ab347b0a2d3d70a4524494cf14130cf3ed10947e;hp=14ef52d5df474ffcf83b5442311c1ecfaeaf89e0;hpb=ead6aad30fdde3921e0224895aa066c907d76c85;p=apitrace diff --git a/gui/apitracecall.h b/gui/apitracecall.h index 14ef52d..12b0216 100644 --- a/gui/apitracecall.h +++ b/gui/apitracecall.h @@ -11,9 +11,15 @@ #include "trace_model.hpp" +class ApiTrace; +class TraceLoader; + class VariantVisitor : public Trace::Visitor { public: + VariantVisitor(TraceLoader *loader) + : m_loader(loader) + {} virtual void visit(Trace::Null *); virtual void visit(Trace::Bool *node); virtual void visit(Trace::SInt *node); @@ -32,18 +38,59 @@ public: return m_variant; } private: + TraceLoader *m_loader; QVariant m_variant; }; +struct ApiTraceError +{ + int callIndex; + QString type; + QString message; +}; + +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); @@ -56,6 +103,9 @@ public: QString toString() const; + unsigned long long value() const; + Signature signature() const; + private: void init(const Trace::Bitmask *bitmask); private: @@ -75,6 +125,8 @@ public: ApiStruct(const Trace::Struct *s = 0); QString toString() const; + Signature signature() const; + QList values() const; private: void init(const Trace::Struct *bitmask); @@ -88,19 +140,20 @@ class ApiArray { public: ApiArray(const Trace::Array *arr = 0); + ApiArray(const QVector &vals); QString toString() const; - QList values() const; + QVector values() const; private: void init(const Trace::Array *arr); private: - QList m_array; + QVector m_array; }; Q_DECLARE_METATYPE(ApiArray); -QString apiVariantToString(const QVariant &variant); +QString apiVariantToString(const QVariant &variant, bool multiLine = false); class ApiTraceFrame; @@ -110,97 +163,185 @@ public: explicit ApiTraceState(const QVariantMap &parseJson); bool isEmpty() const; - QVariantMap parameters() const; - QMap shaderSources() const; - QList textures() const; - QList framebuffers() const; + const QVariantMap & parameters() const; + const QMap & shaderSources() const; + const QVariantMap & uniforms() const; + const QList & textures() const; + const QList & framebuffers() const; + ApiFramebuffer colorBuffer() const; private: QVariantMap m_parameters; QMap m_shaderSources; + QVariantMap m_uniforms; QList m_textures; QList m_framebuffers; }; Q_DECLARE_METATYPE(ApiTraceState); +class ApiTraceCallSignature +{ +public: + 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); + +private: + QString m_name; + QStringList m_argNames; + QUrl m_helpUrl; +}; + class ApiTraceEvent { public: enum Type { - None, - Call, - Frame + None = 0, + Call = 1 << 0, + Frame = 1 << 1 }; public: ApiTraceEvent(); ApiTraceEvent(Type t); + virtual ~ApiTraceEvent(); - Type type() const { return m_type; } + 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(const ApiTraceState &state); + ApiTraceState *state() const; + void setState(ApiTraceState *state); + bool hasState() const + { + return m_state && !m_state->isEmpty(); + } protected: - Type m_type; - ApiTraceState m_state; + 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(); - ApiTraceCall(const Trace::Call *tcall); + ApiTraceCall(ApiTraceFrame *parentFrame, TraceLoader *loader, + const Trace::Call *tcall); ~ApiTraceCall(); int index() const; QString name() const; QStringList argNames() const; - QVariantList arguments() const; + QVector 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); + + QVector originalValues() const; + + bool edited() const; + void setEditedValues(const QVector &lst); + QVector editedValues() const; + void revert(); + + bool contains(const QString &str, + Qt::CaseSensitivity sensitivity) const; + + ApiTrace *parentTrace() const; + QString toHtml() const; - QString filterText() const; + QString searchText() const; QStaticText staticText() const; int numChildren() const; bool hasBinaryData() const; int binaryDataIndex() const; private: int m_index; - QString m_name; - QStringList m_argNames; - QVariantList m_argValues; + ApiTraceCallSignature *m_signature; + QVector m_argValues; QVariant m_returnValue; ApiTraceFrame *m_parentFrame; - QUrl m_helpUrl; + + QVector m_editedValues; + + QString m_error; mutable QString m_richText; - mutable QString m_filterText; - mutable QStaticText m_staticText; - mutable bool m_hasBinaryData; - mutable int m_binaryDataIndex; + mutable QString m_searchText; }; Q_DECLARE_METATYPE(ApiTraceCall*); class ApiTraceFrame : public ApiTraceEvent { public: - ApiTraceFrame(); + ApiTraceFrame(ApiTrace *parent=0); + ~ApiTraceFrame(); int number; - QList calls; + bool isEmpty() const; + + void setParentTrace(ApiTrace *parent); + ApiTrace *parentTrace() const; + + void setNumChildren(int num); int numChildren() const; + int numChildrenToLoad() const; QStaticText staticText() const; + + int callIndex(ApiTraceCall *call) const; + ApiTraceCall *call(int idx) const; + ApiTraceCall *callWithIndex(int index) const; + void addCall(ApiTraceCall *call); + QVector calls() const; + void setCalls(const QVector &calls, + quint64 binaryDataSize); + + ApiTraceCall *findNextCall(ApiTraceCall *from, + const QString &str, + Qt::CaseSensitivity sensitivity) const; + + ApiTraceCall *findPrevCall(ApiTraceCall *from, + const QString &str, + Qt::CaseSensitivity sensitivity) const; + + int binaryDataSize() const; + + bool isLoaded() const; + void setLoaded(bool l); + + void setLastCallIndex(unsigned index); + unsigned lastCallIndex() const; private: - mutable QStaticText m_staticText; + ApiTrace *m_parentTrace; + quint64 m_binaryDataSize; + QVector m_calls; + bool m_loaded; + unsigned m_callsToLoad; + unsigned m_lastCallIndex; }; Q_DECLARE_METATYPE(ApiTraceFrame*);