]> git.cworth.org Git - apitrace/blob - gui/loaderthread.cpp
054545333b37f5d7e7652d4103815581c4da80eb
[apitrace] / gui / loaderthread.cpp
1 #include "loaderthread.h"
2
3 #include "trace_parser.hpp"
4
5 #include <QFile>
6 #include <QHash>
7 #include <QUrl>
8
9 #include <QDebug>
10
11 #define FRAMES_TO_CACHE 100
12
13 static ApiTraceCall *
14 apiCallFromTraceCall(const Trace::Call *call,
15                      const QHash<QString, QUrl> &helpHash,
16                      ApiTraceFrame *frame)
17 {
18     ApiTraceCall *apiCall = new ApiTraceCall(frame, call);
19
20     apiCall->setHelpUrl(helpHash.value(apiCall->name()));
21
22     return apiCall;
23 }
24
25 LoaderThread::LoaderThread(ApiTrace *parent)
26     : QThread(parent),
27       m_frameMarker(ApiTrace::FrameMarker_SwapBuffers),
28       m_trace(parent)
29 {
30 }
31
32 void LoaderThread::run()
33 {
34     QList<ApiTraceFrame*> frames;
35     ApiTraceFrame *currentFrame = 0;
36     int frameCount = 0;
37
38     QHash<QString, QUrl> helpHash;
39
40
41     QFile file(":/resources/glreference.tsv");
42     if (file.open(QIODevice::ReadOnly | QIODevice::Text)) {
43         QString line;
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);
50         }
51     } else {
52         qWarning() << "Couldn't open reference file "
53                    << file.fileName();
54     }
55     file.close();
56
57     Trace::Parser p;
58     if (p.open(m_fileName.toLatin1().constData())) {
59         Trace::Call *call = p.parse_call();
60         while (call) {
61             //std::cout << *call;
62             if (!currentFrame) {
63                 currentFrame = new ApiTraceFrame(m_trace);
64                 currentFrame->number = frameCount;
65                 ++frameCount;
66             }
67             ApiTraceCall *apiCall =
68                 apiCallFromTraceCall(call, helpHash, currentFrame);
69             currentFrame->addCall(apiCall);
70             if (ApiTrace::isCallAFrameMarker(apiCall,
71                                              m_frameMarker)) {
72                 frames.append(currentFrame);
73                 currentFrame = 0;
74                 if (frames.count() >= FRAMES_TO_CACHE) {
75                     emit parsedFrames(frames);
76                     frames.clear();
77                 }
78             }
79             delete call;
80             call = p.parse_call();
81         }
82     }
83     //last frames won't have markers
84     //  it's just a bunch of Delete calls for every object
85     //  after the last SwapBuffers
86     if (currentFrame) {
87         frames.append(currentFrame);
88         currentFrame = 0;
89     }
90     if (frames.count()) {
91         emit parsedFrames(frames);
92     }
93 }
94
95 void LoaderThread::loadFile(const QString &fileName)
96 {
97     m_fileName = fileName;
98     start();
99 }
100
101 ApiTrace::FrameMarker LoaderThread::frameMarker() const
102 {
103     return m_frameMarker;
104 }
105
106 void LoaderThread::setFrameMarker(ApiTrace::FrameMarker marker)
107 {
108     Q_ASSERT(!isRunning());
109     m_frameMarker = marker;
110 }
111
112 #include "loaderthread.moc"