#include "trace_profiler.hpp"
#include <iostream>
+#include <string.h>
+#include <assert.h>
+#include <sstream>
namespace trace {
Profiler::Profiler()
<< " " << cpuDuration
<< std::endl;
}
+
+void Profiler::parseLine(const char* in, Profile* profile)
+{
+ std::stringstream line(in, std::ios_base::in);
+ std::string type;
+
+ if (in[0] == '#' || strlen(in) < 12)
+ return;
+
+ line >> type;
+
+ if (type.compare("call") == 0) {
+ assert(profile->frames.size());
+ Profile::Call call;
+
+ line >> call.no
+ >> call.gpuStart
+ >> call.gpuDuration
+ >> call.cpuStart
+ >> call.cpuDuration
+ >> call.pixels
+ >> call.program
+ >> call.name;
+
+ profile->frames.back().calls.push_back(call);
+ } else if (type.compare("frame_begin") == 0) {
+ Profile::Frame frame;
+ frame.gpuDuration = 0;
+ frame.cpuDuration = 0;
+
+ line >> frame.no
+ >> frame.gpuStart
+ >> frame.cpuStart;
+
+ profile->frames.push_back(frame);
+ } else if (type.compare("frame_end") == 0) {
+ assert(profile->frames.size());
+ Profile::Frame& frame = profile->frames.back();
+ int64_t skipi64;
+
+ line >> frame.no
+ >> skipi64
+ >> frame.gpuDuration
+ >> skipi64
+ >> frame.cpuDuration;
+ }
+}
}