mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
Sanitizes prsector and prwall flags, fixes a mempool crash when exiting the game before the engine gets initialized, and adds polymer_texinvalidate() to fix water/nightvision global palette change. SwissCM is still an asshole.
git-svn-id: https://svn.eduke32.com/eduke32@1428 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
9cf34f9d4f
commit
8982670fbc
3 changed files with 71 additions and 34 deletions
|
@ -240,7 +240,11 @@ typedef struct s_prsector {
|
||||||
int8_t floorshade;
|
int8_t floorshade;
|
||||||
char floorpal, floorxpanning, floorypanning;
|
char floorpal, floorxpanning, floorypanning;
|
||||||
|
|
||||||
char controlstate; // 1: up to date, 2: just allocated
|
struct {
|
||||||
|
int32_t empty : 1;
|
||||||
|
int32_t uptodate : 1;
|
||||||
|
int32_t invalidtex : 1;
|
||||||
|
} flags;
|
||||||
uint32_t invalidid;
|
uint32_t invalidid;
|
||||||
} _prsector;
|
} _prsector;
|
||||||
|
|
||||||
|
@ -261,7 +265,11 @@ typedef struct s_prwall {
|
||||||
|
|
||||||
char underover;
|
char underover;
|
||||||
uint32_t invalidid;
|
uint32_t invalidid;
|
||||||
char controlstate;
|
struct {
|
||||||
|
int32_t empty : 1;
|
||||||
|
int32_t uptodate : 1;
|
||||||
|
int32_t invalidtex : 1;
|
||||||
|
} flags;
|
||||||
} _prwall;
|
} _prwall;
|
||||||
|
|
||||||
typedef struct s_prmirror {
|
typedef struct s_prmirror {
|
||||||
|
@ -295,6 +303,7 @@ void polymer_setanimatesprites(animatespritesptr animatesprites,
|
||||||
int16_t polymer_addlight(_prlight* light);
|
int16_t polymer_addlight(_prlight* light);
|
||||||
void polymer_deletelight(int16_t lighti);
|
void polymer_deletelight(int16_t lighti);
|
||||||
void polymer_invalidatelights(void);
|
void polymer_invalidatelights(void);
|
||||||
|
void polymer_texinvalidate(void);
|
||||||
|
|
||||||
# ifdef POLYMER_C
|
# ifdef POLYMER_C
|
||||||
|
|
||||||
|
|
|
@ -10015,6 +10015,8 @@ void setbrightness(char dabrightness, uint8_t *dapal, char noapply)
|
||||||
gltexinvalidateall();
|
gltexinvalidateall();
|
||||||
if (!(noapply&8) && (newpalettesum != lastpalettesum))
|
if (!(noapply&8) && (newpalettesum != lastpalettesum))
|
||||||
gltexinvalidate8();
|
gltexinvalidate8();
|
||||||
|
if ((rendmode == 4) && (newpalettesum != lastpalettesum))
|
||||||
|
polymer_texinvalidate();
|
||||||
lastpalettesum = newpalettesum;
|
lastpalettesum = newpalettesum;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -629,7 +629,8 @@ int32_t polymer_init(void)
|
||||||
void polymer_uninit(void)
|
void polymer_uninit(void)
|
||||||
{
|
{
|
||||||
polymer_freeboard();
|
polymer_freeboard();
|
||||||
neddestroypool(polymer_pool);
|
if (polymer_pool)
|
||||||
|
neddestroypool(polymer_pool);
|
||||||
}
|
}
|
||||||
|
|
||||||
void polymer_glinit(void)
|
void polymer_glinit(void)
|
||||||
|
@ -791,7 +792,7 @@ void polymer_drawrooms(int32_t daposx, int32_t daposy, int32_t da
|
||||||
i = numsectors-1;
|
i = numsectors-1;
|
||||||
while (i >= 0)
|
while (i >= 0)
|
||||||
{
|
{
|
||||||
prsectors[i]->controlstate = 0;
|
prsectors[i]->flags.uptodate = 0;
|
||||||
prsectors[i]->wallsproffset = 0.0f;
|
prsectors[i]->wallsproffset = 0.0f;
|
||||||
prsectors[i]->floorsproffset = 0.0f;
|
prsectors[i]->floorsproffset = 0.0f;
|
||||||
i--;
|
i--;
|
||||||
|
@ -799,7 +800,7 @@ void polymer_drawrooms(int32_t daposx, int32_t daposy, int32_t da
|
||||||
i = numwalls-1;
|
i = numwalls-1;
|
||||||
while (i >= 0)
|
while (i >= 0)
|
||||||
{
|
{
|
||||||
prwalls[i]->controlstate = 0;
|
prwalls[i]->flags.uptodate = 0;
|
||||||
i--;
|
i--;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1183,6 +1184,24 @@ void polymer_invalidatelights(void)
|
||||||
while (i--);
|
while (i--);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void polymer_texinvalidate(void)
|
||||||
|
{
|
||||||
|
int32_t i;
|
||||||
|
|
||||||
|
i = numsectors-1;
|
||||||
|
while (i >= 0)
|
||||||
|
{
|
||||||
|
prsectors[i]->flags.invalidtex = 1;
|
||||||
|
i--;
|
||||||
|
}
|
||||||
|
i = numwalls-1;
|
||||||
|
while (i >= 0)
|
||||||
|
{
|
||||||
|
prwalls[i]->flags.invalidtex = 1;
|
||||||
|
i--;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// CORE
|
// CORE
|
||||||
static void polymer_displayrooms(int16_t dacursectnum)
|
static void polymer_displayrooms(int16_t dacursectnum)
|
||||||
{
|
{
|
||||||
|
@ -1838,7 +1857,7 @@ static int32_t polymer_initsector(int16_t sectnum)
|
||||||
|
|
||||||
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
|
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
|
||||||
|
|
||||||
s->controlstate = 2; // let updatesector know that everything needs to go
|
s->flags.empty = 1; // let updatesector know that everything needs to go
|
||||||
|
|
||||||
prsectors[sectnum] = s;
|
prsectors[sectnum] = s;
|
||||||
|
|
||||||
|
@ -1894,7 +1913,7 @@ static int32_t polymer_updatesector(int16_t sectnum)
|
||||||
wal = &wall[sec->wallptr + i];
|
wal = &wall[sec->wallptr + i];
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((s->controlstate == 2) ||
|
if ((s->flags.empty) ||
|
||||||
needfloor ||
|
needfloor ||
|
||||||
(sec->floorz != s->floorz) ||
|
(sec->floorz != s->floorz) ||
|
||||||
(sec->ceilingz != s->ceilingz) ||
|
(sec->ceilingz != s->ceilingz) ||
|
||||||
|
@ -1926,7 +1945,7 @@ static int32_t polymer_updatesector(int16_t sectnum)
|
||||||
ceilingpicnum = sec->ceilingpicnum;
|
ceilingpicnum = sec->ceilingpicnum;
|
||||||
if (picanm[ceilingpicnum]&192) ceilingpicnum += animateoffs(ceilingpicnum,sectnum);
|
if (picanm[ceilingpicnum]&192) ceilingpicnum += animateoffs(ceilingpicnum,sectnum);
|
||||||
|
|
||||||
if ((s->controlstate != 2) && (!needfloor) &&
|
if ((!s->flags.empty) && (!needfloor) &&
|
||||||
(sec->floorstat == s->floorstat) &&
|
(sec->floorstat == s->floorstat) &&
|
||||||
(sec->ceilingstat == s->ceilingstat) &&
|
(sec->ceilingstat == s->ceilingstat) &&
|
||||||
(floorpicnum == s->floorpicnum) &&
|
(floorpicnum == s->floorpicnum) &&
|
||||||
|
@ -2045,7 +2064,7 @@ attributes:
|
||||||
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
|
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((s->controlstate != 2) &&
|
if ((!s->flags.empty) && (!s->flags.invalidtex) &&
|
||||||
(sec->floorshade == s->floorshade) &&
|
(sec->floorshade == s->floorshade) &&
|
||||||
(sec->floorpal == s->floorpal) &&
|
(sec->floorpal == s->floorpal) &&
|
||||||
(floorpicnum == s->floorpicnum) &&
|
(floorpicnum == s->floorpicnum) &&
|
||||||
|
@ -2055,6 +2074,8 @@ attributes:
|
||||||
polymer_getbuildmaterial(&s->floor.material, floorpicnum, sec->floorpal, sec->floorshade);
|
polymer_getbuildmaterial(&s->floor.material, floorpicnum, sec->floorpal, sec->floorshade);
|
||||||
polymer_getbuildmaterial(&s->ceil.material, ceilingpicnum, sec->ceilingpal, sec->ceilingshade);
|
polymer_getbuildmaterial(&s->ceil.material, ceilingpicnum, sec->ceilingpal, sec->ceilingshade);
|
||||||
|
|
||||||
|
s->flags.invalidtex = 0;
|
||||||
|
|
||||||
s->floorshade = sec->floorshade;
|
s->floorshade = sec->floorshade;
|
||||||
s->floorpal = sec->floorpal;
|
s->floorpal = sec->floorpal;
|
||||||
s->floorpicnum = floorpicnum;
|
s->floorpicnum = floorpicnum;
|
||||||
|
@ -2090,7 +2111,8 @@ finish:
|
||||||
polymer_computeplane(&s->ceil);
|
polymer_computeplane(&s->ceil);
|
||||||
}
|
}
|
||||||
|
|
||||||
s->controlstate = 1;
|
s->flags.empty = 0;
|
||||||
|
s->flags.uptodate = 1;
|
||||||
|
|
||||||
if (pr_verbosity >= 3) OSD_Printf("PR : Updated sector %i.\n", sectnum);
|
if (pr_verbosity >= 3) OSD_Printf("PR : Updated sector %i.\n", sectnum);
|
||||||
|
|
||||||
|
@ -2257,7 +2279,7 @@ static int32_t polymer_initwall(int16_t wallnum)
|
||||||
|
|
||||||
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
|
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
|
||||||
|
|
||||||
w->controlstate = 2;
|
w->flags.empty = 1;
|
||||||
|
|
||||||
prwalls[wallnum] = w;
|
prwalls[wallnum] = w;
|
||||||
|
|
||||||
|
@ -2323,7 +2345,7 @@ static void polymer_updatewall(int16_t wallnum)
|
||||||
else
|
else
|
||||||
nwallpicnum = 0;
|
nwallpicnum = 0;
|
||||||
|
|
||||||
if ((w->controlstate != 2) &&
|
if ((!w->flags.empty) && (!w->flags.invalidtex) &&
|
||||||
(w->invalidid == invalid) &&
|
(w->invalidid == invalid) &&
|
||||||
(wal->cstat == w->cstat) &&
|
(wal->cstat == w->cstat) &&
|
||||||
(wallpicnum == w->picnum) &&
|
(wallpicnum == w->picnum) &&
|
||||||
|
@ -2340,7 +2362,7 @@ static void polymer_updatewall(int16_t wallnum)
|
||||||
(wall[nwallnum].ypanning == w->nwallypanning) &&
|
(wall[nwallnum].ypanning == w->nwallypanning) &&
|
||||||
(wall[nwallnum].cstat == w->nwallcstat))))
|
(wall[nwallnum].cstat == w->nwallcstat))))
|
||||||
{
|
{
|
||||||
w->controlstate = 1;
|
w->flags.uptodate = 1;
|
||||||
return; // screw you guys I'm going home
|
return; // screw you guys I'm going home
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -2680,7 +2702,9 @@ static void polymer_updatewall(int16_t wallnum)
|
||||||
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
|
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
w->controlstate = 1;
|
w->flags.empty = 0;
|
||||||
|
w->flags.uptodate = 1;
|
||||||
|
w->flags.invalidtex = 0;
|
||||||
|
|
||||||
if (pr_verbosity >= 3) OSD_Printf("PR : Updated wall %i.\n", wallnum);
|
if (pr_verbosity >= 3) OSD_Printf("PR : Updated wall %i.\n", wallnum);
|
||||||
}
|
}
|
||||||
|
@ -2886,14 +2910,14 @@ static inline void polymer_pokesector(int16_t sectnum)
|
||||||
walltype *wal = &wall[sec->wallptr];
|
walltype *wal = &wall[sec->wallptr];
|
||||||
int32_t i = 0;
|
int32_t i = 0;
|
||||||
|
|
||||||
if (!s->controlstate)
|
if (!s->flags.uptodate)
|
||||||
polymer_updatesector(sectnum);
|
polymer_updatesector(sectnum);
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
if ((wal->nextsector != -1) && (!prsectors[wal->nextsector]->controlstate))
|
if ((wal->nextsector != -1) && (!prsectors[wal->nextsector]->flags.uptodate))
|
||||||
polymer_updatesector(wal->nextsector);
|
polymer_updatesector(wal->nextsector);
|
||||||
if (!prwalls[sec->wallptr + i]->controlstate)
|
if (!prwalls[sec->wallptr + i]->flags.uptodate)
|
||||||
polymer_updatewall(sec->wallptr + i);
|
polymer_updatewall(sec->wallptr + i);
|
||||||
|
|
||||||
i++;
|
i++;
|
||||||
|
@ -3318,6 +3342,16 @@ static void polymer_drawmdsprite(spritetype *tspr)
|
||||||
else globalnoeffect=1; //mdloadskin reads this
|
else globalnoeffect=1; //mdloadskin reads this
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// fullscreen tint on global palette change
|
||||||
|
if (hictinting[MAXPALOOKUPS-1].r != 255 ||
|
||||||
|
hictinting[MAXPALOOKUPS-1].g != 255 ||
|
||||||
|
hictinting[MAXPALOOKUPS-1].b != 255)
|
||||||
|
{
|
||||||
|
color[0] *= hictinting[MAXPALOOKUPS-1].r / 255.0;
|
||||||
|
color[1] *= hictinting[MAXPALOOKUPS-1].g / 255.0;
|
||||||
|
color[2] *= hictinting[MAXPALOOKUPS-1].b / 255.0;
|
||||||
|
}
|
||||||
|
|
||||||
if (tspr->cstat & 2)
|
if (tspr->cstat & 2)
|
||||||
{
|
{
|
||||||
if (!(tspr->cstat&512))
|
if (!(tspr->cstat&512))
|
||||||
|
@ -3658,6 +3692,15 @@ static void polymer_getbuildmaterial(_prmaterial* material, int16_t tile
|
||||||
material->diffusemodulation[1] *= (float)hictinting[pal].g / 255.0;
|
material->diffusemodulation[1] *= (float)hictinting[pal].g / 255.0;
|
||||||
material->diffusemodulation[2] *= (float)hictinting[pal].b / 255.0;
|
material->diffusemodulation[2] *= (float)hictinting[pal].b / 255.0;
|
||||||
}
|
}
|
||||||
|
// fullscreen tint on global palette change
|
||||||
|
if (hictinting[MAXPALOOKUPS-1].r != 255 ||
|
||||||
|
hictinting[MAXPALOOKUPS-1].g != 255 ||
|
||||||
|
hictinting[MAXPALOOKUPS-1].b != 255)
|
||||||
|
{
|
||||||
|
material->diffusemodulation[0] *= hictinting[MAXPALOOKUPS-1].r / 255.0;
|
||||||
|
material->diffusemodulation[1] *= hictinting[MAXPALOOKUPS-1].g / 255.0;
|
||||||
|
material->diffusemodulation[2] *= hictinting[MAXPALOOKUPS-1].b / 255.0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -3865,22 +3908,6 @@ static int32_t polymer_bindmaterial(_prmaterial material, int16_t* lights,
|
||||||
// PR_BIT_DIFFUSE_MODULATION
|
// PR_BIT_DIFFUSE_MODULATION
|
||||||
if (programbits & prprogrambits[PR_BIT_DIFFUSE_MODULATION].bit)
|
if (programbits & prprogrambits[PR_BIT_DIFFUSE_MODULATION].bit)
|
||||||
{
|
{
|
||||||
// build-specific hack for fullscreen tint on global palette change
|
|
||||||
if (hictinting[MAXPALOOKUPS-1].r != 255 ||
|
|
||||||
hictinting[MAXPALOOKUPS-1].g != 255 ||
|
|
||||||
hictinting[MAXPALOOKUPS-1].b != 255)
|
|
||||||
{
|
|
||||||
GLfloat color[3];
|
|
||||||
|
|
||||||
color[0] = material.diffusemodulation[0] * (hictinting[MAXPALOOKUPS-1].r / 255.0);
|
|
||||||
color[1] = material.diffusemodulation[1] * (hictinting[MAXPALOOKUPS-1].g / 255.0);
|
|
||||||
color[2] = material.diffusemodulation[2] * (hictinting[MAXPALOOKUPS-1].b / 255.0);
|
|
||||||
|
|
||||||
bglColor4f(color[0],
|
|
||||||
color[1],
|
|
||||||
color[2],
|
|
||||||
material.diffusemodulation[3]);
|
|
||||||
} else
|
|
||||||
bglColor4f(material.diffusemodulation[0],
|
bglColor4f(material.diffusemodulation[0],
|
||||||
material.diffusemodulation[1],
|
material.diffusemodulation[1],
|
||||||
material.diffusemodulation[2],
|
material.diffusemodulation[2],
|
||||||
|
@ -4207,7 +4234,6 @@ static void polymer_compileprogram(int32_t programbits)
|
||||||
}
|
}
|
||||||
|
|
||||||
// LIGHTS
|
// LIGHTS
|
||||||
|
|
||||||
static void polymer_removelight(int16_t lighti)
|
static void polymer_removelight(int16_t lighti)
|
||||||
{
|
{
|
||||||
_prplanelist* oldhead;
|
_prplanelist* oldhead;
|
||||||
|
|
Loading…
Reference in a new issue