/* Copyright (c) 2013 yvt This file is part of OpenSpades. OpenSpades is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. OpenSpades is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenSpades. If not, see . */ #include #include #include #include #include #include #include "GLProfiler.h" #include "IGLDevice.h" // FIXME: use GLSettings? SPADES_SETTING(r_debugTiming); namespace spades { namespace draw { static std::vector levels; void GLProfiler::ResetLevel() { levels.clear(); } GLProfiler::GLProfiler(IGLDevice *device, const char *format, ...) { if (r_debugTiming) { levels.push_back(this); char buf[2048]; va_list va; va_start(va, format); vsprintf(buf, format, va); va_end(va); name = buf; this->device = device; device->Finish(); watch = new Stopwatch; } } GLProfiler::~GLProfiler() { if (r_debugTiming) { SPAssert(levels.back() == this); levels.pop_back(); timeNoFinish = watch->GetTime(); device->Finish(); time = watch->GetTime(); std::string out = GetProfileMessage(); if (!levels.empty()) { GLProfiler *parent = levels.back(); parent->msg += out; } else { static int th = 0; SPLog("Renderer Profile [%8d]\n%s", ++th, out.c_str()); } } } std::string GLProfiler::GetProfileMessage() { char buf[4096]; int indent = static_cast(levels.size() * 2); for (int i = 0; i < indent; i++) buf[i] = ' '; sprintf(buf + indent, "%s - %.3fms (%.3fms w/o glFinish)\n", name.c_str(), time * 1000., timeNoFinish * 1000.); delete watch; std::string out = buf + msg; return out; } } }