-void (*qglVertexPointer)(GLint size, GLenum type, GLsizei stride, const GLvoid *ptr);
-void (*qglColorPointer)(GLint size, GLenum type, GLsizei stride, const GLvoid *ptr);
-void (*qglTexCoordPointer)(GLint size, GLenum type, GLsizei stride, const GLvoid *ptr);
-void (*qglArrayElement)(GLint i);
-void (*qglDrawElements)(GLenum mode, GLsizei count, GLenum type, const GLvoid *indices);
-void (*qglMTexCoord2f)(GLenum, GLfloat, GLfloat);
-void (*qglSelectTexture)(GLenum);
-
-void VID_CheckVertexArrays (void)
-{
- void *prjobj;
- if (COM_CheckParm("-novertex"))
- {
- Con_Printf("...vertex array support disabled\n");
- return;
- }
- if ((prjobj = dlopen(NULL, RTLD_LAZY)) == NULL)
- {
- Con_Printf("Unable to open symbol list for main program.\n");
- return;
- }
- qglMTexCoord2fSGIS = (void *) dlsym(prjobj, "glMTexCoord2fSGIS");
- if ((qglArrayElement = (void *) dlsym(prjobj, "glArrayElement"))
- && (qglColorPointer = (void *) dlsym(prjobj, "glColorPointer"))
-// && (qglDrawArrays = (void *) dlsym(prjobj, "glDrawArrays"))
- && (qglDrawElements = (void *) dlsym(prjobj, "glDrawElements"))
-// && (qglInterleavedArrays = (void *) dlsym(prjobj, "glInterleavedArrays"))
- && (qglTexCoordPointer = (void *) dlsym(prjobj, "glTexCoordPointer"))
- && (qglVertexPointer = (void *) dlsym(prjobj, "glVertexPointer"))
- )
- {
- Con_Printf("...vertex array support detected\n");
- gl_arrays = true;
- dlclose(prjobj);
- return;
- }
-
- Con_Printf("...vertex array support disabled (not detected - get a better driver)\n");
- dlclose(prjobj);
-}