X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=retrace%2Fglstate_params.py;h=094eb6c6c398fb9b41924ad773c816018724bd52;hb=17f8a32687c040c652e6d018100bab08bb0487bd;hp=c5cddb9cd725fbfc95a7d1b752664afc6cebcb25;hpb=529eaa6d004ba0bb502dcd739f8c97bda77525a3;p=apitrace diff --git a/retrace/glstate_params.py b/retrace/glstate_params.py index c5cddb9..094eb6c 100644 --- a/retrace/glstate_params.py +++ b/retrace/glstate_params.py @@ -208,6 +208,7 @@ glGetShader = StateGetter('glGetShaderiv', {I: 'iv'}) glGetProgram = StateGetter('glGetProgram', {I: 'iv'}) glGetProgramARB = StateGetter('glGetProgram', {I: 'iv', F: 'fv', S: 'Stringv'}, 'ARB') glGetFramebufferAttachmentParameter = StateGetter('glGetFramebufferAttachmentParameter', {I: 'iv'}) +glGetSamplerParameter = StateGetter('glGetSamplerParameter', {I: 'iv', F: 'fv'}) class JsonWriter(Visitor): @@ -344,6 +345,7 @@ class StateDumper: print ' if (enabled || binding) {' print ' json.beginMember(enumToString(target));' print ' json.beginObject();' + print ' dumpObjectLabel(json, context, GL_TEXTURE, binding);' self.dump_atoms(glGetTexParameter, 'target') print ' if (!context.ES) {' print ' GLenum levelTarget;' @@ -420,6 +422,25 @@ class StateDumper: print ' }' print + def dump_sampler_params(self): + print ' // GL_SAMPLER_BINDING' + print ' if (context.ARB_sampler_objects) {' + print ' GLint sampler_binding = 0;' + print ' glGetIntegerv(GL_SAMPLER_BINDING, &sampler_binding);' + print ' json.beginMember("GL_SAMPLER_BINDING");' + print ' json.writeInt(sampler_binding);' + print ' json.endMember();' + print ' if (sampler_binding) {' + print ' json.beginMember("GL_SAMPLER");' + print ' json.beginObject();' + print ' dumpObjectLabel(json, context, GL_SAMPLER, sampler_binding);' + for _, _, name in glGetSamplerParameter.iter(): + self.dump_atom(glGetSamplerParameter, 'sampler_binding', name) + print ' json.endObject();' + print ' json.endMember(); // GL_SAMPLER' + print ' }' + print ' }' + def texenv_param_target(self, name): if name == 'GL_TEXTURE_LOD_BIAS': return 'GL_TEXTURE_FILTER_CONTROL' @@ -486,6 +507,7 @@ class StateDumper: for target, binding in texture_targets: print ' dumpTextureTargetParameters(json, context, %s, %s);' % (target, binding) print ' if (unit < max_texture_coords) {' + self.dump_sampler_params() self.dump_texenv_params() print ' }' print ' json.endObject();' @@ -507,6 +529,7 @@ class StateDumper: print ' if (framebuffer) {' print ' json.beginMember("%s");' % target print ' json.beginObject();' + print ' dumpObjectLabel(json, context, GL_FRAMEBUFFER, framebuffer);' print ' for (GLint i = 0; i < max_color_attachments; ++i) {' print ' GLint color_attachment = GL_COLOR_ATTACHMENT0 + i;' print ' dumpFramebufferAttachementParameters(json, %s, color_attachment);' % target @@ -535,17 +558,11 @@ class StateDumper: def dump_atoms(self, getter, *args): for _, _, name in getter.iter(): - self.dump_atom(getter, *(args + (name,))) + self.dump_atom(getter, *(args + (name,))) def dump_atom(self, getter, *args): name = args[-1] - # Avoid crash on MacOSX - # XXX: The right fix would be to look at the support extensions.. - import platform - if name == 'GL_SAMPLER_BINDING' and platform.system() == 'Darwin': - return - print ' // %s' % name print ' {' print ' flushErrors();'