#include "trace_parser.hpp"
+#include <QFile>
+#include <QHash>
+#include <QUrl>
+
+#include <QDebug>
+
#define FRAMES_TO_CACHE 100
static ApiTraceCall *
-apiCallFromTraceCall(const Trace::Call *call)
+apiCallFromTraceCall(const Trace::Call *call,
+ const QHash<QString, QUrl> &helpHash,
+ ApiTraceFrame *frame)
{
- ApiTraceCall *apiCall = new ApiTraceCall();
- apiCall->name = QString::fromStdString(call->sig->name);
+ ApiTraceCall *apiCall = new ApiTraceCall(frame, call);
- QString argumentsText;
- for (int i = 0; i < call->sig->arg_names.size(); ++i) {
- apiCall->argNames +=
- QString::fromStdString(call->sig->arg_names[i]);
- }
- if (call->ret) {
- VariantVisitor retVisitor;
- call->ret->visit(retVisitor);
- apiCall->returnValue = retVisitor.variant();
- }
- for (int i = 0; i < call->args.size(); ++i) {
- VariantVisitor argVisitor;
- call->args[i]->visit(argVisitor);
- apiCall->argValues += argVisitor.variant();
- }
+ apiCall->setHelpUrl(helpHash.value(apiCall->name()));
return apiCall;
}
-LoaderThread::LoaderThread(QObject *parent)
+LoaderThread::LoaderThread(ApiTrace *parent)
: QThread(parent),
- m_frameMarker(ApiTrace::FrameMarker_SwapBuffers)
+ m_frameMarker(ApiTrace::FrameMarker_SwapBuffers),
+ m_trace(parent)
{
}
QList<ApiTraceFrame*> frames;
ApiTraceFrame *currentFrame = 0;
int frameCount = 0;
+
+ QHash<QString, QUrl> helpHash;
+
+
+ QFile file(":/resources/glreference.tsv");
+ if (file.open(QIODevice::ReadOnly | QIODevice::Text)) {
+ QString line;
+ while (!file.atEnd()) {
+ line = file.readLine();
+ QString function = line.section('\t', 0, 0).trimmed();
+ QUrl url = QUrl(line.section('\t', 1, 1).trimmed());
+ //qDebug()<<"function = "<<function<<", url = "<<url.toString();
+ helpHash.insert(function, url);
+ }
+ } else {
+ qWarning() << "Couldn't open reference file "
+ << file.fileName();
+ }
+ file.close();
+
Trace::Parser p;
+ QVector<ApiTraceCall*> calls;
+ quint64 binaryDataSize = 0;
if (p.open(m_fileName.toLatin1().constData())) {
- Trace::Call *call;
- call = p.parse_call();
+ Trace::Call *call = p.parse_call();
while (call) {
//std::cout << *call;
if (!currentFrame) {
- currentFrame = new ApiTraceFrame();
+ currentFrame = new ApiTraceFrame(m_trace);
currentFrame->number = frameCount;
++frameCount;
}
ApiTraceCall *apiCall =
- apiCallFromTraceCall(call);
- apiCall->parentFrame = currentFrame;
- apiCall->index = currentFrame->calls.count();
- currentFrame->calls.append(apiCall);
+ apiCallFromTraceCall(call, helpHash, currentFrame);
+ calls.append(apiCall);
+ if (apiCall->hasBinaryData()) {
+ QByteArray data =
+ apiCall->arguments()[apiCall->binaryDataIndex()].toByteArray();
+ binaryDataSize += data.size();
+ }
if (ApiTrace::isCallAFrameMarker(apiCall,
m_frameMarker)) {
+ calls.squeeze();
+ currentFrame->setCalls(calls, binaryDataSize);
+ calls.clear();
frames.append(currentFrame);
currentFrame = 0;
+ binaryDataSize = 0;
if (frames.count() >= FRAMES_TO_CACHE) {
emit parsedFrames(frames);
frames.clear();
}
}
+ delete call;
call = p.parse_call();
}
}
// it's just a bunch of Delete calls for every object
// after the last SwapBuffers
if (currentFrame) {
+ if (!frames.count()) {
+ calls.squeeze();
+ currentFrame->setCalls(calls, binaryDataSize);
+ }
frames.append(currentFrame);
currentFrame = 0;
}