]> git.cworth.org Git - apitrace/blob - gui/loaderthread.cpp
bc3d32e8e9da6fe1b928610f6cbce07581cf7548
[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;
60         call = p.parse_call();
61         while (call) {
62             //std::cout << *call;
63             if (!currentFrame) {
64                 currentFrame = new ApiTraceFrame();
65                 currentFrame->number = frameCount;
66                 ++frameCount;
67             }
68             ApiTraceCall *apiCall =
69                 apiCallFromTraceCall(call, helpHash);
70             apiCall->setParentFrame(currentFrame);
71             currentFrame->calls.append(apiCall);
72             if (ApiTrace::isCallAFrameMarker(apiCall,
73                                              m_frameMarker)) {
74                 frames.append(currentFrame);
75                 currentFrame = 0;
76                 if (frames.count() >= FRAMES_TO_CACHE) {
77                     emit parsedFrames(frames);
78                     frames.clear();
79                 }
80             }
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"