X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=wrappers%2Fwgltrace.py;h=c001cb1a988ffcd54f0b1ad8e8bd2242480d87f1;hb=207ced34a8b998539414c5213acc6d7a393ca27a;hp=1b0035799fdd648f32bda397b2e4ddb5f86c67e4;hpb=5c298db8fe117e0a445af051335aa0da91c3a31b;p=apitrace diff --git a/wrappers/wgltrace.py b/wrappers/wgltrace.py index 1b00357..c001cb1 100644 --- a/wrappers/wgltrace.py +++ b/wrappers/wgltrace.py @@ -28,7 +28,7 @@ from gltrace import GlTracer -from specs.stdapi import API +from specs.stdapi import Module, API from specs.glapi import glapi from specs.wglapi import wglapi @@ -39,8 +39,24 @@ class WglTracer(GlTracer): "wglGetProcAddress", ] + createContextFunctionNames = [ + 'wglCreateContext', + 'wglCreateContextAttribsARB', + 'wglCreateLayerContext', + ] + + destroyContextFunctionNames = [ + 'wglDeleteContext', + ] + + makeCurrentFunctionNames = [ + 'wglMakeCurrent', + 'wglMakeContextCurrentARB', + 'wglMakeContextCurrentEXT', + ] + def traceFunctionImplBody(self, function): - if function.name == 'wglDeleteContext': + if function.name in self.destroyContextFunctionNames: # Unlike other GL APIs like EGL or GLX, WGL will make the context # inactive if it's currently the active context. print ' if (_wglGetCurrentContext() == hglrc) {' @@ -50,11 +66,11 @@ class WglTracer(GlTracer): GlTracer.traceFunctionImplBody(self, function) - if function.name == 'wglCreateContext': + if function.name in self.createContextFunctionNames: print ' if (_result)' print ' gltrace::createContext((uintptr_t)_result);' - if function.name == 'wglMakeCurrent': + if function.name in self.makeCurrentFunctionNames: print ' if (_result) {' print ' if (hglrc != NULL)' print ' gltrace::setContext((uintptr_t)hglrc);' @@ -80,8 +96,10 @@ if __name__ == '__main__': print '#include "glproc.hpp"' print '#include "glsize.hpp"' print + module = Module() + module.mergeModule(glapi) + module.mergeModule(wglapi) api = API() - api.addApi(glapi) - api.addApi(wglapi) + api.addModule(module) tracer = WglTracer() tracer.traceApi(api)