1 #include "loaderthread.h"
3 #include "trace_parser.hpp"
11 #define FRAMES_TO_CACHE 100
14 apiCallFromTraceCall(const Trace::Call *call,
15 const QHash<QString, QUrl> &helpHash,
18 ApiTraceCall *apiCall = new ApiTraceCall(frame, call);
20 apiCall->setHelpUrl(helpHash.value(apiCall->name()));
25 LoaderThread::LoaderThread(ApiTrace *parent)
27 m_frameMarker(ApiTrace::FrameMarker_SwapBuffers),
32 void LoaderThread::run()
34 QList<ApiTraceFrame*> frames;
35 ApiTraceFrame *currentFrame = 0;
38 QHash<QString, QUrl> helpHash;
41 QFile file(":/resources/glreference.tsv");
42 if (file.open(QIODevice::ReadOnly | QIODevice::Text)) {
44 while (!file.atEnd()) {
45 line = file.readLine();
46 QString function = line.section('\t', 0, 0).trimmed();
47 QUrl url = QUrl(line.section('\t', 1, 1).trimmed());
48 //qDebug()<<"function = "<<function<<", url = "<<url.toString();
49 helpHash.insert(function, url);
52 qWarning() << "Couldn't open reference file "
58 if (p.open(m_fileName.toLatin1().constData())) {
59 Trace::Call *call = p.parse_call();
63 currentFrame = new ApiTraceFrame(m_trace);
64 currentFrame->number = frameCount;
67 ApiTraceCall *apiCall =
68 apiCallFromTraceCall(call, helpHash, currentFrame);
69 currentFrame->addCall(apiCall);
70 if (ApiTrace::isCallAFrameMarker(apiCall,
72 frames.append(currentFrame);
74 if (frames.count() >= FRAMES_TO_CACHE) {
75 emit parsedFrames(frames);
80 call = p.parse_call();
83 //last frames won't have markers
84 // it's just a bunch of Delete calls for every object
85 // after the last SwapBuffers
87 frames.append(currentFrame);
91 emit parsedFrames(frames);
95 void LoaderThread::loadFile(const QString &fileName)
97 m_fileName = fileName;
101 ApiTrace::FrameMarker LoaderThread::frameMarker() const
103 return m_frameMarker;
106 void LoaderThread::setFrameMarker(ApiTrace::FrameMarker marker)
108 Q_ASSERT(!isRunning());
109 m_frameMarker = marker;
112 #include "loaderthread.moc"