]> git.cworth.org Git - apitrace/blob - gui/loaderthread.cpp
1f5474425f214d79ca1e162d34b33ccb7f653e09
[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 {
17     ApiTraceCall *apiCall = new ApiTraceCall(call);
18
19     apiCall->setHelpUrl(helpHash.value(apiCall->name()));
20
21     //force generation of the internal state
22     apiCall->filterText();
23     return apiCall;
24 }
25
26 LoaderThread::LoaderThread(QObject *parent)
27     : QThread(parent),
28       m_frameMarker(ApiTrace::FrameMarker_SwapBuffers)
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();
64                 currentFrame->number = frameCount;
65                 ++frameCount;
66             }
67             ApiTraceCall *apiCall =
68                 apiCallFromTraceCall(call, helpHash);
69             apiCall->setParentFrame(currentFrame);
70             currentFrame->calls.append(apiCall);
71             if (ApiTrace::isCallAFrameMarker(apiCall,
72                                              m_frameMarker)) {
73                 frames.append(currentFrame);
74                 currentFrame = 0;
75                 if (frames.count() >= FRAMES_TO_CACHE) {
76                     emit parsedFrames(frames);
77                     frames.clear();
78                 }
79             }
80             delete call;
81             call = p.parse_call();
82         }
83     }
84     //last frames won't have markers
85     //  it's just a bunch of Delete calls for every object
86     //  after the last SwapBuffers
87     if (currentFrame) {
88         frames.append(currentFrame);
89         currentFrame = 0;
90     }
91     if (frames.count()) {
92         emit parsedFrames(frames);
93     }
94 }
95
96 void LoaderThread::loadFile(const QString &fileName)
97 {
98     m_fileName = fileName;
99     start();
100 }
101
102 ApiTrace::FrameMarker LoaderThread::frameMarker() const
103 {
104     return m_frameMarker;
105 }
106
107 void LoaderThread::setFrameMarker(ApiTrace::FrameMarker marker)
108 {
109     Q_ASSERT(!isRunning());
110     m_frameMarker = marker;
111 }
112
113 #include "loaderthread.moc"