# HG changeset patch # User reimar # Date 1127664721 0 # Node ID c3dc7f3c716ca688f89295e7a003c47bec2e177e # Parent 3b108342a9835a89dc013ae0abe2895f56dd3f69 get rid of global getProcAddress variable diff -r 3b108342a983 -r c3dc7f3c716c libvo/gl_common.c --- a/libvo/gl_common.c Sun Sep 25 16:11:21 2005 +0000 +++ b/libvo/gl_common.c Sun Sep 25 16:12:01 2005 +0000 @@ -213,12 +213,11 @@ return NULL; } -static void *(*getProcAddress)(const GLubyte *procName) = NULL; - /** * \brief find the function pointers of some useful OpenGL extensions + * \param getProcAddress function to resolve function names, may be NULL */ -static void getFunctions() { +static void getFunctions(void *(*getProcAddress)(const GLubyte *)) { if (!getProcAddress) getProcAddress = setNull; GenBuffers = getProcAddress("glGenBuffers"); @@ -794,8 +793,7 @@ wglDeleteContext(*context); *context = new_context; *vinfo = new_vinfo; - getProcAddress = w32gpa; - getFunctions(); + getFunctions(w32gpa); // and inform that reinit is neccessary return SET_WINDOW_REINIT; @@ -906,19 +904,19 @@ &vo_dwidth, &vo_dheight, &tmp, &tmp); } if (!keep_context) { + void *(*getProcAddress)(const GLubyte *); if (*context) glXDestroyContext(mDisplay, *context); *context = new_context; if (*vinfo) XFree(*vinfo); *vinfo = new_vinfo; - if (!getProcAddress) getProcAddress = getdladdr("glXGetProcAddress"); if (!getProcAddress) getProcAddress = getdladdr("glXGetProcAddressARB"); if (!getProcAddress) getProcAddress = getdladdr; - getFunctions(); + getFunctions(getProcAddress); // and inform that reinit is neccessary return SET_WINDOW_REINIT;