X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=retrace%2Fretrace.hpp;h=228c81352e979046ece2e8040d2f885ef7b27051;hb=65ba497caca56134f9b4f18658d104ce89092c11;hp=a019de787cae5de55432ba2797f9355cca45c3ad;hpb=ab8142ff4ab07a92565676ead5b0ad4607492cbc;p=apitrace diff --git a/retrace/retrace.hpp b/retrace/retrace.hpp index a019de7..228c813 100644 --- a/retrace/retrace.hpp +++ b/retrace/retrace.hpp @@ -36,6 +36,7 @@ #include "trace_model.hpp" #include "trace_parser.hpp" +#include "trace_profiler.hpp" namespace image { @@ -47,6 +48,7 @@ namespace retrace { extern trace::Parser parser; +extern trace::Profiler profiler; /** @@ -58,6 +60,7 @@ private: uintptr_t next; public: + inline ScopedAllocator() : next(0) { } @@ -79,21 +82,14 @@ public: return static_cast(&buf[1]); } - template< class T > - inline T * - alloc(size_t n = 1) { - return static_cast(alloc(sizeof(T) * n)); - } - /** * Allocate an array with the same dimensions as the specified value. */ - template< class T > - inline T * - alloc(const trace::Value *value) { + inline void * + alloc(const trace::Value *value, size_t size) { const trace::Array *array = dynamic_cast(value); if (array) { - return alloc(array->size()); + return alloc(array->size() * size); } const trace::Null *null = dynamic_cast(value); if (null) { @@ -146,6 +142,9 @@ extern bool debug; * Add profiling data to the dump when retracing. */ extern bool profiling; +extern bool profilingCpuTimes; +extern bool profilingGpuTimes; +extern bool profilingPixelsDrawn; /** * State dumping. @@ -153,9 +152,24 @@ extern bool profiling; extern bool dumpingState; +enum Driver { + DRIVER_DEFAULT, + DRIVER_HARDWARE, // force hardware + DRIVER_SOFTWARE, + DRIVER_REFERENCE, + DRIVER_NULL, + DRIVER_MODULE, +}; + +extern Driver driver; +extern const char *driverModule; + extern bool doubleBuffer; extern bool coreProfile; +extern unsigned frameNo; +extern unsigned callNo; + std::ostream &warning(trace::Call &call); @@ -203,6 +217,24 @@ public: }; +class Dumper +{ +public: + virtual image::Image * + getSnapshot(void) { + return NULL; + } + + virtual bool + dumpState(std::ostream &os) { + return false; + } +}; + + +extern Dumper *dumper; + + void setUp(void); @@ -212,11 +244,7 @@ addCallbacks(retrace::Retracer &retracer); void frameComplete(trace::Call &call); -image::Image * -getSnapshot(void); -bool -dumpState(std::ostream &os); void flushRendering(void);