mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-11 18:50:46 +00:00
Material/program validation and diffuse modulation bit.
git-svn-id: https://svn.eduke32.com/eduke32@1154 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
bd98e3676b
commit
0f385d3021
2 changed files with 186 additions and 141 deletions
|
@ -132,6 +132,7 @@ typedef struct s_prlight {
|
||||||
#define PR_INFO_LOG_BUFFER_SIZE 512
|
#define PR_INFO_LOG_BUFFER_SIZE 512
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
|
PR_BIT_DIFFUSE_MODULATION,
|
||||||
PR_BIT_DEFAULT, // must be just before last
|
PR_BIT_DEFAULT, // must be just before last
|
||||||
PR_BIT_COUNT // must be last
|
PR_BIT_COUNT // must be last
|
||||||
} prbittype;
|
} prbittype;
|
||||||
|
@ -196,6 +197,7 @@ static void polymer_drawskybox(short tilenum);
|
||||||
static void polymer_drawmdsprite(spritetype *tspr);
|
static void polymer_drawmdsprite(spritetype *tspr);
|
||||||
static void polymer_loadmodelvbos(md3model* m);
|
static void polymer_loadmodelvbos(md3model* m);
|
||||||
// GPU PROGRAMS
|
// GPU PROGRAMS
|
||||||
|
static void polymer_bindmaterial(_prmaterial material);
|
||||||
static void polymer_compileprogram(int programbits);
|
static void polymer_compileprogram(int programbits);
|
||||||
|
|
||||||
# endif // !POLYMER_C
|
# endif // !POLYMER_C
|
||||||
|
|
|
@ -124,6 +124,19 @@ int lightcount;
|
||||||
|
|
||||||
// PROGRAMS
|
// PROGRAMS
|
||||||
_prprogrambit prprogrambits[PR_BIT_COUNT] = {
|
_prprogrambit prprogrambits[PR_BIT_COUNT] = {
|
||||||
|
{
|
||||||
|
.bit = 1 << PR_BIT_DIFFUSE_MODULATION,
|
||||||
|
.vert_def =
|
||||||
|
"",
|
||||||
|
.vert_prog =
|
||||||
|
"gl_FrontColor = gl_Color;\n"
|
||||||
|
"\n",
|
||||||
|
.frag_def =
|
||||||
|
"",
|
||||||
|
.frag_prog =
|
||||||
|
" result *= vec4(gl_Color);\n"
|
||||||
|
"\n",
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.bit = 1 << PR_BIT_DEFAULT,
|
.bit = 1 << PR_BIT_DEFAULT,
|
||||||
.vert_def =
|
.vert_def =
|
||||||
|
@ -134,10 +147,10 @@ _prprogrambit prprogrambits[PR_BIT_COUNT] = {
|
||||||
" gl_Position = ftransform();\n"
|
" gl_Position = ftransform();\n"
|
||||||
"}\n",
|
"}\n",
|
||||||
.frag_def =
|
.frag_def =
|
||||||
"\n"
|
|
||||||
"void main(void)\n"
|
"void main(void)\n"
|
||||||
"{\n"
|
"{\n"
|
||||||
" vec4 result = vec4(1.0, 1.0, 1.0, 1.0);\n",
|
" vec4 result = vec4(1.0, 1.0, 1.0, 1.0);\n"
|
||||||
|
"\n",
|
||||||
.frag_prog =
|
.frag_prog =
|
||||||
" gl_FragColor = result;\n"
|
" gl_FragColor = result;\n"
|
||||||
"}\n",
|
"}\n",
|
||||||
|
@ -895,21 +908,127 @@ static void polymer_displayrooms(short dacursectnum)
|
||||||
static void polymer_drawplane(short sectnum, short wallnum, _prplane* plane, int indicecount)
|
static void polymer_drawplane(short sectnum, short wallnum, _prplane* plane, int indicecount)
|
||||||
{
|
{
|
||||||
|
|
||||||
if ((depth < 1) && (plane != NULL) &&
|
// if ((depth < 1) && (plane != NULL) &&
|
||||||
(wallnum >= 0) && (wall[wallnum].overpicnum == 560)) // insert mirror condition here
|
// (wallnum >= 0) && (wall[wallnum].overpicnum == 560)) // insert mirror condition here
|
||||||
{
|
// {
|
||||||
int gx, gy, gz, px, py, pz;
|
// int gx, gy, gz, px, py, pz;
|
||||||
float coeff;
|
// float coeff;
|
||||||
|
//
|
||||||
|
// // set the stencil to 1 and clear the area to black where the sector floor is
|
||||||
|
// bglDisable(GL_TEXTURE_2D);
|
||||||
|
// bglDisable(GL_FOG);
|
||||||
|
// bglColor4f(0.0f, 1.0f, 0.0f, 1.0f);
|
||||||
|
// bglDepthMask(GL_FALSE);
|
||||||
|
//
|
||||||
|
// bglEnable(GL_STENCIL_TEST);
|
||||||
|
// bglStencilOp(GL_KEEP, GL_KEEP, GL_INCR);
|
||||||
|
// bglStencilFunc(GL_EQUAL, 0, 0xffffffff);
|
||||||
|
//
|
||||||
|
// if (plane->vbo && (pr_vbos > 0))
|
||||||
|
// {
|
||||||
|
// OMGDRAWSHITVBO;
|
||||||
|
// }
|
||||||
|
// else
|
||||||
|
// {
|
||||||
|
// OMGDRAWSHIT;
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// bglDepthMask(GL_TRUE);
|
||||||
|
//
|
||||||
|
// // set the depth to 1 where we put the stencil by drawing a screen aligned quad
|
||||||
|
// bglStencilFunc(GL_EQUAL, 1, 0xffffffff);
|
||||||
|
// bglStencilOp(GL_KEEP, GL_KEEP, GL_KEEP);
|
||||||
|
// bglDepthFunc(GL_ALWAYS);
|
||||||
|
// bglMatrixMode(GL_PROJECTION);
|
||||||
|
// bglPushMatrix();
|
||||||
|
// bglLoadIdentity();
|
||||||
|
// bglMatrixMode(GL_MODELVIEW);
|
||||||
|
// bglPushMatrix();
|
||||||
|
// bglLoadIdentity();
|
||||||
|
//
|
||||||
|
// bglColor4f(0.0f, 0.0f, 0.0f, 1.0f);
|
||||||
|
// bglBegin(GL_QUADS);
|
||||||
|
// bglVertex3f(-1.0f, -1.0f, 1.0f);
|
||||||
|
// bglVertex3f(1.0f, -1.0f, 1.0f);
|
||||||
|
// bglVertex3f(1.0f, 1.0f, 1.0f);
|
||||||
|
// bglVertex3f(-1.0f, 1.0f, 1.0f);
|
||||||
|
// bglEnd();
|
||||||
|
//
|
||||||
|
// bglMatrixMode(GL_PROJECTION);
|
||||||
|
// bglPopMatrix();
|
||||||
|
// bglMatrixMode(GL_MODELVIEW);
|
||||||
|
// bglPopMatrix();
|
||||||
|
// bglDepthFunc(GL_LEQUAL);
|
||||||
|
// bglEnable(GL_TEXTURE_2D);
|
||||||
|
// bglEnable(GL_FOG);
|
||||||
|
// // finally draw the shit
|
||||||
|
// bglPushMatrix();
|
||||||
|
// bglClipPlane(GL_CLIP_PLANE0, plane->plane);
|
||||||
|
// polymer_inb4mirror(plane->buffer, plane->plane);
|
||||||
|
// bglCullFace(GL_FRONT);
|
||||||
|
// bglEnable(GL_CLIP_PLANE0);
|
||||||
|
//
|
||||||
|
// if (wallnum >= 0)
|
||||||
|
// preparemirror(globalposx, globalposy, 0, globalang,
|
||||||
|
// 0, wallnum, 0, &gx, &gy, &viewangle);
|
||||||
|
//
|
||||||
|
// gx = globalposx;
|
||||||
|
// gy = globalposy;
|
||||||
|
// gz = globalposz;
|
||||||
|
//
|
||||||
|
// // map the player pos from build to polymer
|
||||||
|
// px = globalposy;
|
||||||
|
// py = -globalposz / 16;
|
||||||
|
// pz = -globalposx;
|
||||||
|
//
|
||||||
|
// // calculate new player position on the other side of the mirror
|
||||||
|
// // this way the basic build visibility shit can be used (wallvisible)
|
||||||
|
// coeff = -plane->plane[0] * px +
|
||||||
|
// -plane->plane[1] * py +
|
||||||
|
// -plane->plane[2] * pz +
|
||||||
|
// -plane->plane[3];
|
||||||
|
//
|
||||||
|
// coeff /= (float)(plane->plane[0] * plane->plane[0] +
|
||||||
|
// plane->plane[1] * plane->plane[1] +
|
||||||
|
// plane->plane[2] * plane->plane[2]);
|
||||||
|
//
|
||||||
|
// px = coeff*plane->plane[0]*2 + px;
|
||||||
|
// py = coeff*plane->plane[1]*2 + py;
|
||||||
|
// pz = coeff*plane->plane[2]*2 + pz;
|
||||||
|
//
|
||||||
|
// // map back from polymer to build
|
||||||
|
// globalposx = -pz;
|
||||||
|
// globalposy = px;
|
||||||
|
// globalposz = -py * 16;
|
||||||
|
//
|
||||||
|
// depth++;
|
||||||
|
// mirrorfrom[depth] = wallnum;
|
||||||
|
// polymer_displayrooms(sectnum);
|
||||||
|
// depth--;
|
||||||
|
//
|
||||||
|
// globalposx = gx;
|
||||||
|
// globalposy = gy;
|
||||||
|
// globalposz = gz;
|
||||||
|
//
|
||||||
|
// bglDisable(GL_CLIP_PLANE0);
|
||||||
|
// bglCullFace(GL_BACK);
|
||||||
|
// bglMatrixMode(GL_MODELVIEW);
|
||||||
|
// bglPopMatrix();
|
||||||
|
//
|
||||||
|
// bglColor4f(plane->material.diffusemodulation[0],
|
||||||
|
// plane->material.diffusemodulation[1],
|
||||||
|
// plane->material.diffusemodulation[2],
|
||||||
|
// 0.0f);
|
||||||
|
// }
|
||||||
|
// else
|
||||||
|
// bglColor4f(plane->material.diffusemodulation[0],
|
||||||
|
// plane->material.diffusemodulation[1],
|
||||||
|
// plane->material.diffusemodulation[2],
|
||||||
|
// plane->material.diffusemodulation[3]);
|
||||||
|
|
||||||
// set the stencil to 1 and clear the area to black where the sector floor is
|
// bglBindTexture(GL_TEXTURE_2D, plane->material.diffusemap);
|
||||||
bglDisable(GL_TEXTURE_2D);
|
|
||||||
bglDisable(GL_FOG);
|
|
||||||
bglColor4f(0.0f, 1.0f, 0.0f, 1.0f);
|
|
||||||
bglDepthMask(GL_FALSE);
|
|
||||||
|
|
||||||
bglEnable(GL_STENCIL_TEST);
|
polymer_bindmaterial(plane->material);
|
||||||
bglStencilOp(GL_KEEP, GL_KEEP, GL_INCR);
|
|
||||||
bglStencilFunc(GL_EQUAL, 0, 0xffffffff);
|
|
||||||
|
|
||||||
if (plane->vbo && (pr_vbos > 0))
|
if (plane->vbo && (pr_vbos > 0))
|
||||||
{
|
{
|
||||||
|
@ -920,115 +1039,12 @@ static void polymer_drawplane(short sectnum, short wallnum, _prplane* pl
|
||||||
OMGDRAWSHIT;
|
OMGDRAWSHIT;
|
||||||
}
|
}
|
||||||
|
|
||||||
bglDepthMask(GL_TRUE);
|
// if ((depth < 1) && (plane->plane != NULL) &&
|
||||||
|
// (wallnum >= 0) && (wall[wallnum].overpicnum == 560)) // insert mirror condition here
|
||||||
// set the depth to 1 where we put the stencil by drawing a screen aligned quad
|
// {
|
||||||
bglStencilFunc(GL_EQUAL, 1, 0xffffffff);
|
// bglDisable(GL_STENCIL_TEST);
|
||||||
bglStencilOp(GL_KEEP, GL_KEEP, GL_KEEP);
|
// bglClear(GL_STENCIL_BUFFER_BIT);
|
||||||
bglDepthFunc(GL_ALWAYS);
|
// }
|
||||||
bglMatrixMode(GL_PROJECTION);
|
|
||||||
bglPushMatrix();
|
|
||||||
bglLoadIdentity();
|
|
||||||
bglMatrixMode(GL_MODELVIEW);
|
|
||||||
bglPushMatrix();
|
|
||||||
bglLoadIdentity();
|
|
||||||
|
|
||||||
bglColor4f(0.0f, 0.0f, 0.0f, 1.0f);
|
|
||||||
bglBegin(GL_QUADS);
|
|
||||||
bglVertex3f(-1.0f, -1.0f, 1.0f);
|
|
||||||
bglVertex3f(1.0f, -1.0f, 1.0f);
|
|
||||||
bglVertex3f(1.0f, 1.0f, 1.0f);
|
|
||||||
bglVertex3f(-1.0f, 1.0f, 1.0f);
|
|
||||||
bglEnd();
|
|
||||||
|
|
||||||
bglMatrixMode(GL_PROJECTION);
|
|
||||||
bglPopMatrix();
|
|
||||||
bglMatrixMode(GL_MODELVIEW);
|
|
||||||
bglPopMatrix();
|
|
||||||
bglDepthFunc(GL_LEQUAL);
|
|
||||||
bglEnable(GL_TEXTURE_2D);
|
|
||||||
bglEnable(GL_FOG);
|
|
||||||
// finally draw the shit
|
|
||||||
bglPushMatrix();
|
|
||||||
bglClipPlane(GL_CLIP_PLANE0, plane->plane);
|
|
||||||
polymer_inb4mirror(plane->buffer, plane->plane);
|
|
||||||
bglCullFace(GL_FRONT);
|
|
||||||
bglEnable(GL_CLIP_PLANE0);
|
|
||||||
|
|
||||||
if (wallnum >= 0)
|
|
||||||
preparemirror(globalposx, globalposy, 0, globalang,
|
|
||||||
0, wallnum, 0, &gx, &gy, &viewangle);
|
|
||||||
|
|
||||||
gx = globalposx;
|
|
||||||
gy = globalposy;
|
|
||||||
gz = globalposz;
|
|
||||||
|
|
||||||
// map the player pos from build to polymer
|
|
||||||
px = globalposy;
|
|
||||||
py = -globalposz / 16;
|
|
||||||
pz = -globalposx;
|
|
||||||
|
|
||||||
// calculate new player position on the other side of the mirror
|
|
||||||
// this way the basic build visibility shit can be used (wallvisible)
|
|
||||||
coeff = -plane->plane[0] * px +
|
|
||||||
-plane->plane[1] * py +
|
|
||||||
-plane->plane[2] * pz +
|
|
||||||
-plane->plane[3];
|
|
||||||
|
|
||||||
coeff /= (float)(plane->plane[0] * plane->plane[0] +
|
|
||||||
plane->plane[1] * plane->plane[1] +
|
|
||||||
plane->plane[2] * plane->plane[2]);
|
|
||||||
|
|
||||||
px = coeff*plane->plane[0]*2 + px;
|
|
||||||
py = coeff*plane->plane[1]*2 + py;
|
|
||||||
pz = coeff*plane->plane[2]*2 + pz;
|
|
||||||
|
|
||||||
// map back from polymer to build
|
|
||||||
globalposx = -pz;
|
|
||||||
globalposy = px;
|
|
||||||
globalposz = -py * 16;
|
|
||||||
|
|
||||||
depth++;
|
|
||||||
mirrorfrom[depth] = wallnum;
|
|
||||||
polymer_displayrooms(sectnum);
|
|
||||||
depth--;
|
|
||||||
|
|
||||||
globalposx = gx;
|
|
||||||
globalposy = gy;
|
|
||||||
globalposz = gz;
|
|
||||||
|
|
||||||
bglDisable(GL_CLIP_PLANE0);
|
|
||||||
bglCullFace(GL_BACK);
|
|
||||||
bglMatrixMode(GL_MODELVIEW);
|
|
||||||
bglPopMatrix();
|
|
||||||
|
|
||||||
bglColor4f(plane->material.diffusemodulation[0],
|
|
||||||
plane->material.diffusemodulation[1],
|
|
||||||
plane->material.diffusemodulation[2],
|
|
||||||
0.0f);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
bglColor4f(plane->material.diffusemodulation[0],
|
|
||||||
plane->material.diffusemodulation[1],
|
|
||||||
plane->material.diffusemodulation[2],
|
|
||||||
plane->material.diffusemodulation[3]);
|
|
||||||
|
|
||||||
bglBindTexture(GL_TEXTURE_2D, plane->material.diffusemap);
|
|
||||||
if (plane->vbo && (pr_vbos > 0))
|
|
||||||
{
|
|
||||||
OMGDRAWSHITVBO;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
OMGDRAWSHIT;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((depth < 1) && (plane->plane != NULL) &&
|
|
||||||
(wallnum >= 0) && (wall[wallnum].overpicnum == 560)) // insert mirror condition here
|
|
||||||
{
|
|
||||||
bglDisable(GL_STENCIL_TEST);
|
|
||||||
bglClear(GL_STENCIL_BUFFER_BIT);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void polymer_inb4mirror(GLfloat* buffer, GLdouble* plane)
|
static void polymer_inb4mirror(GLfloat* buffer, GLdouble* plane)
|
||||||
|
@ -2567,6 +2583,37 @@ static void polymer_loadmodelvbos(md3model* m)
|
||||||
}
|
}
|
||||||
|
|
||||||
// GPU PROGRAMS
|
// GPU PROGRAMS
|
||||||
|
static void polymer_bindmaterial(_prmaterial material)
|
||||||
|
{
|
||||||
|
int programbits;
|
||||||
|
|
||||||
|
programbits = prprogrambits[PR_BIT_DEFAULT].bit;
|
||||||
|
|
||||||
|
// --------- bit validation
|
||||||
|
|
||||||
|
// PR_BIT_DIFFUSE_MODULATION
|
||||||
|
if ((material.diffusemodulation[0] != 1.0f) || (material.diffusemodulation[1] != 1.0f) ||
|
||||||
|
(material.diffusemodulation[2] != 1.0f) || (material.diffusemodulation[3] != 1.0f))
|
||||||
|
programbits |= prprogrambits[PR_BIT_DIFFUSE_MODULATION].bit;
|
||||||
|
|
||||||
|
// --------- program compiling
|
||||||
|
if (!prprograms[programbits])
|
||||||
|
polymer_compileprogram(programbits);
|
||||||
|
|
||||||
|
// --------- bit setup
|
||||||
|
|
||||||
|
// PR_BIT_DIFFUSE_MODULATION
|
||||||
|
if (programbits & prprogrambits[PR_BIT_DIFFUSE_MODULATION].bit)
|
||||||
|
{
|
||||||
|
bglColor4f(material.diffusemodulation[0],
|
||||||
|
material.diffusemodulation[1],
|
||||||
|
material.diffusemodulation[2],
|
||||||
|
material.diffusemodulation[3]);
|
||||||
|
}
|
||||||
|
|
||||||
|
bglUseProgramObjectARB(prprograms[programbits]);
|
||||||
|
}
|
||||||
|
|
||||||
static void polymer_compileprogram(int programbits)
|
static void polymer_compileprogram(int programbits)
|
||||||
{
|
{
|
||||||
int i, enabledbits;
|
int i, enabledbits;
|
||||||
|
@ -2574,57 +2621,51 @@ static void polymer_compileprogram(int programbits)
|
||||||
GLcharARB* source[PR_BIT_COUNT * 2];
|
GLcharARB* source[PR_BIT_COUNT * 2];
|
||||||
GLcharARB infobuffer[PR_INFO_LOG_BUFFER_SIZE];
|
GLcharARB infobuffer[PR_INFO_LOG_BUFFER_SIZE];
|
||||||
|
|
||||||
// ========= VERTEX
|
// --------- VERTEX
|
||||||
vert = bglCreateShaderObjectARB(GL_VERTEX_SHADER_ARB);
|
vert = bglCreateShaderObjectARB(GL_VERTEX_SHADER_ARB);
|
||||||
|
|
||||||
enabledbits = 0;
|
enabledbits = i = 0;
|
||||||
while (i < PR_BIT_COUNT)
|
while (i < PR_BIT_COUNT)
|
||||||
{
|
{
|
||||||
if (programbits & prprogrambits[i].bit)
|
if (programbits & prprogrambits[i].bit)
|
||||||
{
|
source[enabledbits++] = prprogrambits[i].vert_def;
|
||||||
source[i] = prprogrambits[i].vert_def;
|
|
||||||
enabledbits++;
|
|
||||||
}
|
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
i = 0;
|
i = 0;
|
||||||
while (i < PR_BIT_COUNT)
|
while (i < PR_BIT_COUNT)
|
||||||
{
|
{
|
||||||
if (programbits & prprogrambits[i].bit)
|
if (programbits & prprogrambits[i].bit)
|
||||||
source[enabledbits + i] = prprogrambits[i].vert_prog;
|
source[enabledbits++] = prprogrambits[i].vert_prog;
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
bglShaderSourceARB(vert, enabledbits * 2, (const GLcharARB**)source, NULL);
|
bglShaderSourceARB(vert, enabledbits, (const GLcharARB**)source, NULL);
|
||||||
|
|
||||||
bglCompileShaderARB(vert);
|
bglCompileShaderARB(vert);
|
||||||
|
|
||||||
// ========= FRAGMENT
|
// --------- FRAGMENT
|
||||||
frag = bglCreateShaderObjectARB(GL_FRAGMENT_SHADER_ARB);
|
frag = bglCreateShaderObjectARB(GL_FRAGMENT_SHADER_ARB);
|
||||||
|
|
||||||
enabledbits = i = 0;
|
enabledbits = i = 0;
|
||||||
while (i < PR_BIT_COUNT)
|
while (i < PR_BIT_COUNT)
|
||||||
{
|
{
|
||||||
if (programbits & prprogrambits[i].bit)
|
if (programbits & prprogrambits[i].bit)
|
||||||
{
|
source[enabledbits++] = prprogrambits[i].frag_def;
|
||||||
source[i] = prprogrambits[i].frag_def;
|
|
||||||
enabledbits++;
|
|
||||||
}
|
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
i = 0;
|
i = 0;
|
||||||
while (i < PR_BIT_COUNT)
|
while (i < PR_BIT_COUNT)
|
||||||
{
|
{
|
||||||
if (programbits & prprogrambits[i].bit)
|
if (programbits & prprogrambits[i].bit)
|
||||||
source[enabledbits + i] = prprogrambits[i].frag_prog;
|
source[enabledbits++] = prprogrambits[i].frag_prog;
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
bglShaderSourceARB(frag, enabledbits * 2, (const GLcharARB**)source, NULL);
|
bglShaderSourceARB(frag, enabledbits, (const GLcharARB**)source, NULL);
|
||||||
|
|
||||||
bglCompileShaderARB(frag);
|
bglCompileShaderARB(frag);
|
||||||
|
|
||||||
// ========= PROGRAM
|
// --------- PROGRAM
|
||||||
program = bglCreateProgramObjectARB();
|
program = bglCreateProgramObjectARB();
|
||||||
|
|
||||||
bglAttachObjectARB(program, vert);
|
bglAttachObjectARB(program, vert);
|
||||||
|
@ -2636,7 +2677,9 @@ static void polymer_compileprogram(int programbits)
|
||||||
|
|
||||||
prprograms[programbits] = program;
|
prprograms[programbits] = program;
|
||||||
|
|
||||||
OSD_Printf("Shader log info:\n%s\n", infobuffer);
|
if (pr_verbosity >= 1) OSD_Printf("Compiling GPU program with bits %i...\n", programbits);
|
||||||
|
if (infobuffer[0])
|
||||||
|
if (pr_verbosity >= 1) OSD_Printf("Info log:\n%s\n", infobuffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue