FrameMarker_Finish,
FrameMarker_Clear
};
+ enum SearchResult {
+ SearchResult_NotFound,
+ SearchResult_Found,
+ SearchResult_Wrapped
+ };
+ struct SearchRequest {
+ enum Direction {
+ Next,
+ Prev
+ };
+ SearchRequest()
+ : direction(Next)
+ {}
+ SearchRequest(Direction dir,
+ ApiTraceFrame *f,
+ ApiTraceCall *call,
+ QString str,
+ Qt::CaseSensitivity caseSens)
+ : direction(dir),
+ frame(f),
+ from(call),
+ text(str),
+ cs(caseSens)
+ {}
+ Direction direction;
+ ApiTraceFrame *frame;
+ ApiTraceCall *from;
+ QString text;
+ Qt::CaseSensitivity cs;
+ };
+
static bool isCallAFrameMarker(const ApiTraceCall *call,
FrameMarker marker);
public:
ApiTraceState defaultState() const;
- QVector<ApiTraceCall*> calls() const;
ApiTraceCall *callWithIndex(int idx) const;
- int numCalls() const;
QList<ApiTraceFrame*> frames() const;
ApiTraceFrame *frameAt(int idx) const;
public slots:
void setFileName(const QString &name);
- void setFrameMarker(FrameMarker marker);
void save();
void loadFrame(ApiTraceFrame *frame);
+ void findNext(ApiTraceFrame *frame,
+ ApiTraceCall *call,
+ const QString &str,
+ Qt::CaseSensitivity sensitivity);
+ void findPrev(ApiTraceFrame *frame,
+ ApiTraceCall *call,
+ const QString &str,
+ Qt::CaseSensitivity sensitivity);
+ void findFrameStart(ApiTraceFrame *frame);
+ void findFrameEnd(ApiTraceFrame *frame);
+ void findCallIndex(int index);
+ void setCallError(const ApiTraceError &error);
+
signals:
void loadTrace(const QString &name);
void changed(ApiTraceCall *call);
void startedSaving();
void saved();
+ void findResult(const ApiTrace::SearchRequest &request,
+ ApiTrace::SearchResult result,
+ ApiTraceCall *call);
void beginAddingFrames(int oldCount, int numAdded);
void endAddingFrames();
- void callsAdded(int oldCount, int numAdded);
void beginLoadingFrame(ApiTraceFrame *frame, int numAdded);
void endLoadingFrame(ApiTraceFrame *frame);
+ void foundFrameStart(ApiTraceFrame *frame);
+ void foundFrameEnd(ApiTraceFrame *frame);
+ void foundCallIndex(ApiTraceCall *call);
+
+signals:
+ void loaderSearch(const ApiTrace::SearchRequest &request);
+ void loaderFindFrameStart(ApiTraceFrame *frame);
+ void loaderFindFrameEnd(ApiTraceFrame *frame);
+ void loaderFindCallIndex(int index);
private slots:
void addFrames(const QList<ApiTraceFrame*> &frames);
void slotSaved();
void finishedParsing();
- void frameLoadFinished(ApiTraceFrame *frame);
+ void loaderFrameLoaded(ApiTraceFrame *frame,
+ const QVector<ApiTraceCall*> &calls,
+ quint64 binaryDataSize);
+ void loaderSearchResult(const ApiTrace::SearchRequest &request,
+ ApiTrace::SearchResult result,
+ ApiTraceCall *call);
private:
- void detectFrames();
+ int callInFrame(int callIdx) const;
private:
QString m_fileName;
QString m_tempFileName;
QList<ApiTraceFrame*> m_frames;
- QVector<ApiTraceCall*> m_calls;
FrameMarker m_frameMarker;
bool m_needsSaving;
QSet<ApiTraceCall*> m_errors;
+ QList< QPair<ApiTraceFrame*, ApiTraceError> > m_queuedErrors;
};
#endif