X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=retrace%2Fglretrace.hpp;h=7441b56938e22481e0110b181b74b7de81a55c98;hb=HEAD;hp=27085d4886a645101aff02ed26417b7684269078;hpb=b5801e3f55037abe79a3465d8b053ae47bd49de1;p=apitrace diff --git a/retrace/glretrace.hpp b/retrace/glretrace.hpp index 27085d4..7441b56 100644 --- a/retrace/glretrace.hpp +++ b/retrace/glretrace.hpp @@ -35,27 +35,40 @@ namespace glretrace { struct Context { Context(glws::Context* context) : wsContext(context), + drawable(0), activeProgram(0), used(false) { } - ~Context() - { - delete wsContext; - } + ~Context(); glws::Context* wsContext; + + // Bound drawable + glws::Drawable *drawable; + GLuint activeProgram; bool used; + + // Context must be current + inline bool + hasExtension(const char *extension) const { + return wsContext->hasExtension(extension); + } }; extern bool insideList; extern bool insideGlBeginEnd; +extern bool supportsARBShaderObjects; +Context * +getCurrentContext(void); + + +int +parseAttrib(const trace::Value *attribs, int param, int default_); -extern glws::Drawable *currentDrawable; -extern Context *currentContext; glws::Drawable * createDrawable(glws::Profile profile); @@ -63,6 +76,9 @@ createDrawable(glws::Profile profile); glws::Drawable * createDrawable(void); +glws::Drawable * +createPbuffer(int width, int height); + Context * createContext(Context *shareContext, glws::Profile profile); @@ -82,7 +98,6 @@ extern const retrace::Entry glx_callbacks[]; extern const retrace::Entry wgl_callbacks[]; extern const retrace::Entry egl_callbacks[]; -void frame_start(); void frame_complete(trace::Call &call); void initContext(); @@ -90,8 +105,8 @@ void initContext(); void updateDrawable(int width, int height); void flushQueries(); -void beginProfile(trace::Call &call); -void endProfile(trace::Call &call); +void beginProfile(trace::Call &call, bool isDraw); +void endProfile(trace::Call &call, bool isDraw); } /* namespace glretrace */