From: José Fonseca Date: Tue, 7 Jun 2011 19:58:52 +0000 (+0100) Subject: Add some sanity checks to catch state clobering. X-Git-Url: https://git.cworth.org/git?a=commitdiff_plain;h=4f8e71e7e9ccb2e6b7a4bcbe646485002f83b15c;p=apitrace Add some sanity checks to catch state clobering. --- diff --git a/glstate.cpp b/glstate.cpp index 1a821a0..2d55ce8 100644 --- a/glstate.cpp +++ b/glstate.cpp @@ -955,13 +955,60 @@ dumpFramebuffer(JSONWriter &json) } +static const GLenum bindings[] = { + GL_DRAW_BUFFER, + GL_READ_BUFFER, + GL_PIXEL_PACK_BUFFER_BINDING, + GL_PIXEL_UNPACK_BUFFER_BINDING, + GL_TEXTURE_BINDING_1D, + GL_TEXTURE_BINDING_2D, + GL_TEXTURE_BINDING_3D, + GL_TEXTURE_BINDING_RECTANGLE, + GL_TEXTURE_BINDING_CUBE_MAP, + GL_DRAW_FRAMEBUFFER_BINDING, + GL_READ_FRAMEBUFFER_BINDING, + GL_RENDERBUFFER_BINDING, + GL_DRAW_BUFFER0, + GL_DRAW_BUFFER1, + GL_DRAW_BUFFER2, + GL_DRAW_BUFFER3, + GL_DRAW_BUFFER4, + GL_DRAW_BUFFER5, + GL_DRAW_BUFFER6, + GL_DRAW_BUFFER7, +}; + + +#define NUM_BINDINGS sizeof(bindings)/sizeof(bindings[0]) + + void dumpCurrentContext(std::ostream &os) { JSONWriter json(os); + +#ifndef NDEBUG + GLint old_bindings[NUM_BINDINGS]; + for (unsigned i = 0; i < NUM_BINDINGS; ++i) { + old_bindings[i] = 0; + glGetIntegerv(bindings[i], &old_bindings[i]); + } +#endif + dumpParameters(json); dumpShaders(json); dumpTextures(json); dumpFramebuffer(json); + +#ifndef NDEBUG + for (unsigned i = 0; i < NUM_BINDINGS; ++i) { + GLint new_binding = 0; + glGetIntegerv(bindings[i], &new_binding); + if (new_binding != old_bindings[i]) { + std::cerr << "warning: " << enumToString(bindings[i]) << " was clobbered\n"; + } + } +#endif + }