Changed: Give priority to ARB extensions in tests
--HG-- branch : compatibility
This commit is contained in:
parent
d4fb36d1eb
commit
a77bddf265
1 changed files with 24 additions and 26 deletions
|
@ -46,21 +46,21 @@ CVertexProgamDrvInfosGL::CVertexProgamDrvInfosGL(CDriverGL *drv, ItGPUPrgDrvInfo
|
||||||
H_AUTO_OGL(CVertexProgamDrvInfosGL_CVertexProgamDrvInfosGL);
|
H_AUTO_OGL(CVertexProgamDrvInfosGL_CVertexProgamDrvInfosGL);
|
||||||
|
|
||||||
// Extension must exist
|
// Extension must exist
|
||||||
nlassert (drv->_Extensions.NVVertexProgram
|
nlassert (drv->_Extensions.ARBVertexProgram
|
||||||
|
|| drv->_Extensions.NVVertexProgram
|
||||||
|| drv->_Extensions.EXTVertexShader
|
|| drv->_Extensions.EXTVertexShader
|
||||||
|| drv->_Extensions.ARBVertexProgram
|
|
||||||
);
|
);
|
||||||
|
|
||||||
#ifndef USE_OPENGLES
|
#ifndef USE_OPENGLES
|
||||||
if (drv->_Extensions.NVVertexProgram) // NVIDIA implemntation
|
// Generate a program
|
||||||
{
|
if (drv->_Extensions.ARBVertexProgram) // ARB implementation
|
||||||
// Generate a program
|
|
||||||
nglGenProgramsNV (1, &ID);
|
|
||||||
}
|
|
||||||
else if (drv->_Extensions.ARBVertexProgram) // ARB implementation
|
|
||||||
{
|
{
|
||||||
nglGenProgramsARB(1, &ID);
|
nglGenProgramsARB(1, &ID);
|
||||||
}
|
}
|
||||||
|
else if (drv->_Extensions.NVVertexProgram) // NVIDIA implementation
|
||||||
|
{
|
||||||
|
nglGenProgramsNV(1, &ID);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ID = nglGenVertexShadersEXT(1); // ATI implementation
|
ID = nglGenVertexShadersEXT(1); // ATI implementation
|
||||||
|
@ -74,7 +74,7 @@ bool CDriverGL::supportVertexProgram(CVertexProgram::TProfile profile) const
|
||||||
{
|
{
|
||||||
H_AUTO_OGL(CVertexProgamDrvInfosGL_supportVertexProgram)
|
H_AUTO_OGL(CVertexProgamDrvInfosGL_supportVertexProgram)
|
||||||
return (profile == CVertexProgram::nelvp)
|
return (profile == CVertexProgram::nelvp)
|
||||||
&& (_Extensions.NVVertexProgram || _Extensions.EXTVertexShader || _Extensions.ARBVertexProgram);
|
&& (_Extensions.ARBVertexProgram || _Extensions.NVVertexProgram || _Extensions.EXTVertexShader);
|
||||||
}
|
}
|
||||||
|
|
||||||
// ***************************************************************************
|
// ***************************************************************************
|
||||||
|
@ -1774,7 +1774,6 @@ bool CDriverGL::compileVertexProgram(NL3D::CVertexProgram *program)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ***************************************************************************
|
// ***************************************************************************
|
||||||
|
|
||||||
bool CDriverGL::activeVertexProgram(CVertexProgram *program)
|
bool CDriverGL::activeVertexProgram(CVertexProgram *program)
|
||||||
{
|
{
|
||||||
H_AUTO_OGL(CDriverGL_activeVertexProgram)
|
H_AUTO_OGL(CDriverGL_activeVertexProgram)
|
||||||
|
@ -1783,14 +1782,14 @@ bool CDriverGL::activeVertexProgram(CVertexProgram *program)
|
||||||
if (program && !CDriverGL::compileVertexProgram(program)) return false;
|
if (program && !CDriverGL::compileVertexProgram(program)) return false;
|
||||||
|
|
||||||
// Extension
|
// Extension
|
||||||
if (_Extensions.NVVertexProgram)
|
if (_Extensions.ARBVertexProgram)
|
||||||
{
|
|
||||||
return activeNVVertexProgram(program);
|
|
||||||
}
|
|
||||||
else if (_Extensions.ARBVertexProgram)
|
|
||||||
{
|
{
|
||||||
return activeARBVertexProgram(program);
|
return activeARBVertexProgram(program);
|
||||||
}
|
}
|
||||||
|
else if (_Extensions.NVVertexProgram)
|
||||||
|
{
|
||||||
|
return activeNVVertexProgram(program);
|
||||||
|
}
|
||||||
else if (_Extensions.EXTVertexShader)
|
else if (_Extensions.EXTVertexShader)
|
||||||
{
|
{
|
||||||
return activeEXTVertexShader(program);
|
return activeEXTVertexShader(program);
|
||||||
|
@ -1808,15 +1807,7 @@ void CDriverGL::enableVertexProgramDoubleSidedColor(bool doubleSided)
|
||||||
|
|
||||||
#ifndef USE_OPENGLES
|
#ifndef USE_OPENGLES
|
||||||
// Vertex program exist ?
|
// Vertex program exist ?
|
||||||
if (_Extensions.NVVertexProgram)
|
if (_Extensions.ARBVertexProgram)
|
||||||
{
|
|
||||||
// change mode (not cached because supposed to be rare)
|
|
||||||
if(doubleSided)
|
|
||||||
glEnable (GL_VERTEX_PROGRAM_TWO_SIDE_NV);
|
|
||||||
else
|
|
||||||
glDisable (GL_VERTEX_PROGRAM_TWO_SIDE_NV);
|
|
||||||
}
|
|
||||||
else if (_Extensions.ARBVertexProgram)
|
|
||||||
{
|
{
|
||||||
// change mode (not cached because supposed to be rare)
|
// change mode (not cached because supposed to be rare)
|
||||||
if(doubleSided)
|
if(doubleSided)
|
||||||
|
@ -1824,16 +1815,23 @@ void CDriverGL::enableVertexProgramDoubleSidedColor(bool doubleSided)
|
||||||
else
|
else
|
||||||
glDisable (GL_VERTEX_PROGRAM_TWO_SIDE_ARB);
|
glDisable (GL_VERTEX_PROGRAM_TWO_SIDE_ARB);
|
||||||
}
|
}
|
||||||
|
else if (_Extensions.NVVertexProgram)
|
||||||
|
{
|
||||||
|
// change mode (not cached because supposed to be rare)
|
||||||
|
if(doubleSided)
|
||||||
|
glEnable (GL_VERTEX_PROGRAM_TWO_SIDE_NV);
|
||||||
|
else
|
||||||
|
glDisable (GL_VERTEX_PROGRAM_TWO_SIDE_NV);
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ***************************************************************************
|
// ***************************************************************************
|
||||||
bool CDriverGL::supportVertexProgramDoubleSidedColor() const
|
bool CDriverGL::supportVertexProgramDoubleSidedColor() const
|
||||||
{
|
{
|
||||||
H_AUTO_OGL(CDriverGL_supportVertexProgramDoubleSidedColor)
|
H_AUTO_OGL(CDriverGL_supportVertexProgramDoubleSidedColor)
|
||||||
// currently only supported by NV_VERTEX_PROGRAM && ARB_VERTEX_PROGRAM
|
// currently only supported by NV_VERTEX_PROGRAM && ARB_VERTEX_PROGRAM
|
||||||
return _Extensions.NVVertexProgram || _Extensions.ARBVertexProgram;
|
return _Extensions.ARBVertexProgram || _Extensions.NVVertexProgram;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef NL_STATIC
|
#ifdef NL_STATIC
|
||||||
|
|
Loading…
Reference in a new issue