mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 19:20:38 +00:00
Usual cleanup type stuff involving vectors and variable scopes.
git-svn-id: https://svn.eduke32.com/eduke32@5802 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
0e713e698f
commit
951ad678c4
3 changed files with 200 additions and 218 deletions
|
@ -1157,24 +1157,24 @@ void rotatepoint(vec2_t pivot, vec2_t p, int16_t daang, vec2_t *p2) ATTRIBU
|
||||||
int32_t lastwall(int16_t point);
|
int32_t lastwall(int16_t point);
|
||||||
int32_t nextsectorneighborz(int16_t sectnum, int32_t refz, int16_t topbottom, int16_t direction);
|
int32_t nextsectorneighborz(int16_t sectnum, int32_t refz, int16_t topbottom, int16_t direction);
|
||||||
|
|
||||||
int32_t getceilzofslopeptr(const sectortype *sec, int32_t dax, int32_t day) ATTRIBUTE((nonnull(1)));
|
int32_t getceilzofslopeptr(const usectortype *sec, int32_t dax, int32_t day) ATTRIBUTE((nonnull(1)));
|
||||||
int32_t getflorzofslopeptr(const sectortype *sec, int32_t dax, int32_t day) ATTRIBUTE((nonnull(1)));
|
int32_t getflorzofslopeptr(const usectortype *sec, int32_t dax, int32_t day) ATTRIBUTE((nonnull(1)));
|
||||||
void getzsofslopeptr(const sectortype *sec, int32_t dax, int32_t day,
|
void getzsofslopeptr(const usectortype *sec, int32_t dax, int32_t day,
|
||||||
int32_t *ceilz, int32_t *florz) ATTRIBUTE((nonnull(1,4,5)));
|
int32_t *ceilz, int32_t *florz) ATTRIBUTE((nonnull(1,4,5)));
|
||||||
|
|
||||||
FORCE_INLINE int32_t getceilzofslope(int16_t sectnum, int32_t dax, int32_t day)
|
FORCE_INLINE int32_t getceilzofslope(int16_t sectnum, int32_t dax, int32_t day)
|
||||||
{
|
{
|
||||||
return getceilzofslopeptr(§or[sectnum], dax, day);
|
return getceilzofslopeptr((usectortype *)§or[sectnum], dax, day);
|
||||||
}
|
}
|
||||||
|
|
||||||
FORCE_INLINE int32_t getflorzofslope(int16_t sectnum, int32_t dax, int32_t day)
|
FORCE_INLINE int32_t getflorzofslope(int16_t sectnum, int32_t dax, int32_t day)
|
||||||
{
|
{
|
||||||
return getflorzofslopeptr(§or[sectnum], dax, day);
|
return getflorzofslopeptr((usectortype *)§or[sectnum], dax, day);
|
||||||
}
|
}
|
||||||
|
|
||||||
FORCE_INLINE void getzsofslope(int16_t sectnum, int32_t dax, int32_t day, int32_t *ceilz, int32_t *florz)
|
FORCE_INLINE void getzsofslope(int16_t sectnum, int32_t dax, int32_t day, int32_t *ceilz, int32_t *florz)
|
||||||
{
|
{
|
||||||
getzsofslopeptr(§or[sectnum], dax, day, ceilz, florz);
|
getzsofslopeptr((usectortype *)§or[sectnum], dax, day, ceilz, florz);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Is <wal> a red wall in a safe fashion, i.e. only if consistency invariant
|
// Is <wal> a red wall in a safe fashion, i.e. only if consistency invariant
|
||||||
|
|
|
@ -1425,7 +1425,7 @@ static int32_t *lastx;
|
||||||
|
|
||||||
int32_t halfxdim16, midydim16;
|
int32_t halfxdim16, midydim16;
|
||||||
|
|
||||||
static const int32_t hitscangoalx = (1<<29)-1, hitscangoaly = (1<<29)-1;
|
static vec2_t const hitscangoal = { (1<<29)-1, (1<<29)-1 };
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
int32_t hitallsprites = 0;
|
int32_t hitallsprites = 0;
|
||||||
#endif
|
#endif
|
||||||
|
@ -1473,9 +1473,9 @@ char inpreparemirror = 0;
|
||||||
static int32_t mirrorsx1, mirrorsy1, mirrorsx2, mirrorsy2;
|
static int32_t mirrorsx1, mirrorsy1, mirrorsx2, mirrorsy2;
|
||||||
|
|
||||||
static int32_t setviewcnt = 0; // interface layers use this now
|
static int32_t setviewcnt = 0; // interface layers use this now
|
||||||
static int32_t bakframeplace[4], bakxsiz[4], bakysiz[4];
|
static intptr_t bakframeplace[4];
|
||||||
static int32_t bakwindowx1[4], bakwindowy1[4];
|
static int32_t bakxsiz[4], bakysiz[4];
|
||||||
static int32_t bakwindowx2[4], bakwindowy2[4];
|
static vec2_t bakwindowxy1[4], bakwindowxy2[4];
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
static int32_t bakrendmode;
|
static int32_t bakrendmode;
|
||||||
#endif
|
#endif
|
||||||
|
@ -9847,7 +9847,6 @@ int32_t setgamemode(char davidoption, int32_t daxdim, int32_t daydim, int32_t da
|
||||||
//
|
//
|
||||||
void nextpage(void)
|
void nextpage(void)
|
||||||
{
|
{
|
||||||
int32_t i;
|
|
||||||
permfifotype *per;
|
permfifotype *per;
|
||||||
|
|
||||||
//char snotbuf[32];
|
//char snotbuf[32];
|
||||||
|
@ -9867,7 +9866,7 @@ void nextpage(void)
|
||||||
{
|
{
|
||||||
case 200:
|
case 200:
|
||||||
begindrawing(); //{{{
|
begindrawing(); //{{{
|
||||||
for (i=permtail; i!=permhead; i=((i+1)&(MAXPERMS-1)))
|
for (int i=permtail; i!=permhead; i=((i+1)&(MAXPERMS-1)))
|
||||||
{
|
{
|
||||||
per = &permfifo[i];
|
per = &permfifo[i];
|
||||||
if ((per->pagesleft > 0) && (per->pagesleft <= numpages))
|
if ((per->pagesleft > 0) && (per->pagesleft <= numpages))
|
||||||
|
@ -9881,7 +9880,7 @@ void nextpage(void)
|
||||||
showframe(0);
|
showframe(0);
|
||||||
|
|
||||||
begindrawing(); //{{{
|
begindrawing(); //{{{
|
||||||
for (i=permtail; i!=permhead; i=((i+1)&(MAXPERMS-1)))
|
for (int i=permtail; i!=permhead; i=((i+1)&(MAXPERMS-1)))
|
||||||
{
|
{
|
||||||
per = &permfifo[i];
|
per = &permfifo[i];
|
||||||
if (per->pagesleft >= 130)
|
if (per->pagesleft >= 130)
|
||||||
|
@ -9908,7 +9907,7 @@ void nextpage(void)
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
omdtims = mdtims; mdtims = getticks();
|
omdtims = mdtims; mdtims = getticks();
|
||||||
|
|
||||||
for (int i = 0; i < Numsprites; i++)
|
for (int i = 0; i < Numsprites; ++i)
|
||||||
if ((mdpause && spriteext[i].mdanimtims) || (spriteext[i].flags & SPREXT_NOMDANIM))
|
if ((mdpause && spriteext[i].mdanimtims) || (spriteext[i].flags & SPREXT_NOMDANIM))
|
||||||
spriteext[i].mdanimtims += mdtims - omdtims;
|
spriteext[i].mdanimtims += mdtims - omdtims;
|
||||||
#endif
|
#endif
|
||||||
|
@ -9974,7 +9973,7 @@ int32_t inside(int32_t x, int32_t y, int16_t sectnum)
|
||||||
{
|
{
|
||||||
uint32_t cnt1 = 0, cnt2 = 0;
|
uint32_t cnt1 = 0, cnt2 = 0;
|
||||||
uwalltype const * wal = (uwalltype *) &wall[sector[sectnum].wallptr];
|
uwalltype const * wal = (uwalltype *) &wall[sector[sectnum].wallptr];
|
||||||
int32_t i = sector[sectnum].wallnum;
|
int wallsleft = sector[sectnum].wallnum;
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
|
@ -10013,9 +10012,9 @@ int32_t inside(int32_t x, int32_t y, int16_t sectnum)
|
||||||
cnt2 ^= (((v1.x^v2.x) >= 0) ? v1.x : (v1.x*v2.y-v2.x*v1.y)^v2.y);
|
cnt2 ^= (((v1.x^v2.x) >= 0) ? v1.x : (v1.x*v2.y-v2.x*v1.y)^v2.y);
|
||||||
}
|
}
|
||||||
|
|
||||||
wal++; i--;
|
wal++;
|
||||||
}
|
}
|
||||||
while (i);
|
while (--wallsleft);
|
||||||
|
|
||||||
return (cnt1|cnt2)>>31;
|
return (cnt1|cnt2)>>31;
|
||||||
}
|
}
|
||||||
|
@ -10611,7 +10610,7 @@ int32_t hitscan(const vec3_t *sv, int16_t sectnum, int32_t vx, int32_t vy, int32
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
restart_grand:
|
restart_grand:
|
||||||
#endif
|
#endif
|
||||||
hit->pos.x = hitscangoalx; hit->pos.y = hitscangoaly;
|
*(vec2_t *)&hit->pos = hitscangoal;
|
||||||
|
|
||||||
clipsectorlist[0] = sectnum;
|
clipsectorlist[0] = sectnum;
|
||||||
tempshortcnt = 0; tempshortnum = 1;
|
tempshortcnt = 0; tempshortnum = 1;
|
||||||
|
@ -11246,28 +11245,25 @@ static inline int32_t inside_z_p(int32_t x, int32_t y, int32_t z, int16_t i)
|
||||||
//
|
//
|
||||||
void updatesector(int32_t x, int32_t y, int16_t *sectnum)
|
void updatesector(int32_t x, int32_t y, int16_t *sectnum)
|
||||||
{
|
{
|
||||||
int32_t i;
|
|
||||||
|
|
||||||
if (inside_p(x,y,*sectnum))
|
if (inside_p(x,y,*sectnum))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if ((unsigned)*sectnum < (unsigned)numsectors)
|
if ((unsigned)*sectnum < (unsigned)numsectors)
|
||||||
{
|
{
|
||||||
const uwalltype *wal = (uwalltype *)&wall[sector[*sectnum].wallptr];
|
const uwalltype *wal = (uwalltype *)&wall[sector[*sectnum].wallptr];
|
||||||
int32_t j = sector[*sectnum].wallnum;
|
int wallsleft = sector[*sectnum].wallnum;
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
i = wal->nextsector;
|
int const next = wal->nextsector;
|
||||||
if (inside_p(x, y, i))
|
if (inside_p(x, y, next))
|
||||||
SET_AND_RETURN(*sectnum, i);
|
SET_AND_RETURN(*sectnum, next);
|
||||||
|
wal++;
|
||||||
wal++; j--;
|
|
||||||
}
|
}
|
||||||
while (j != 0);
|
while (--wallsleft);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i=numsectors-1; i>=0; i--)
|
for (int i=numsectors-1; i>=0; --i)
|
||||||
if (inside_p(x, y, i))
|
if (inside_p(x, y, i))
|
||||||
SET_AND_RETURN(*sectnum, i);
|
SET_AND_RETURN(*sectnum, i);
|
||||||
|
|
||||||
|
@ -11306,28 +11302,25 @@ void updatesectorbreadth(int32_t x, int32_t y, int16_t *sectnum)
|
||||||
|
|
||||||
void updatesectorexclude(int32_t x, int32_t y, int16_t *sectnum, const uint8_t *excludesectbitmap)
|
void updatesectorexclude(int32_t x, int32_t y, int16_t *sectnum, const uint8_t *excludesectbitmap)
|
||||||
{
|
{
|
||||||
int32_t i;
|
|
||||||
|
|
||||||
if (inside_exclude_p(x, y, *sectnum, excludesectbitmap))
|
if (inside_exclude_p(x, y, *sectnum, excludesectbitmap))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (*sectnum >= 0 && *sectnum < numsectors)
|
if (*sectnum >= 0 && *sectnum < numsectors)
|
||||||
{
|
{
|
||||||
const uwalltype *wal = (uwalltype *)&wall[sector[*sectnum].wallptr];
|
const uwalltype *wal = (uwalltype *)&wall[sector[*sectnum].wallptr];
|
||||||
int32_t j = sector[*sectnum].wallnum;
|
int wallsleft = sector[*sectnum].wallnum;
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
i = wal->nextsector;
|
int const next = wal->nextsector;
|
||||||
if (inside_exclude_p(x, y, i, excludesectbitmap))
|
if (inside_exclude_p(x, y, next, excludesectbitmap))
|
||||||
SET_AND_RETURN(*sectnum, i);
|
SET_AND_RETURN(*sectnum, next);
|
||||||
|
wal++;
|
||||||
wal++; j--;
|
|
||||||
}
|
}
|
||||||
while (j != 0);
|
while (--wallsleft);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i=numsectors-1; i>=0; i--)
|
for (int i=numsectors-1; i>=0; --i)
|
||||||
if (inside_exclude_p(x, y, i, excludesectbitmap))
|
if (inside_exclude_p(x, y, i, excludesectbitmap))
|
||||||
SET_AND_RETURN(*sectnum, i);
|
SET_AND_RETURN(*sectnum, i);
|
||||||
|
|
||||||
|
@ -11339,13 +11332,8 @@ void updatesectorexclude(int32_t x, int32_t y, int16_t *sectnum, const uint8_t *
|
||||||
// (not initial anymore because it follows the sector updating due to TROR)
|
// (not initial anymore because it follows the sector updating due to TROR)
|
||||||
void updatesectorz(int32_t x, int32_t y, int32_t z, int16_t *sectnum)
|
void updatesectorz(int32_t x, int32_t y, int32_t z, int16_t *sectnum)
|
||||||
{
|
{
|
||||||
int32_t i;
|
|
||||||
|
|
||||||
if ((uint32_t)(*sectnum) < 2*MAXSECTORS)
|
if ((uint32_t)(*sectnum) < 2*MAXSECTORS)
|
||||||
{
|
{
|
||||||
const uwalltype *wal;
|
|
||||||
int32_t j, cz, fz;
|
|
||||||
|
|
||||||
int32_t nofirstzcheck = 0;
|
int32_t nofirstzcheck = 0;
|
||||||
|
|
||||||
if (*sectnum >= MAXSECTORS)
|
if (*sectnum >= MAXSECTORS)
|
||||||
|
@ -11355,42 +11343,43 @@ void updatesectorz(int32_t x, int32_t y, int32_t z, int16_t *sectnum)
|
||||||
}
|
}
|
||||||
|
|
||||||
// this block used to be outside the "if" and caused crashes in Polymost Mapster32
|
// this block used to be outside the "if" and caused crashes in Polymost Mapster32
|
||||||
|
int32_t cz, fz;
|
||||||
getzsofslope(*sectnum, x, y, &cz, &fz);
|
getzsofslope(*sectnum, x, y, &cz, &fz);
|
||||||
|
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
if (z < cz)
|
if (z < cz)
|
||||||
{
|
{
|
||||||
i = yax_getneighborsect(x, y, *sectnum, YAX_CEILING);
|
int const next = yax_getneighborsect(x, y, *sectnum, YAX_CEILING);
|
||||||
if (i >= 0 && z >= getceilzofslope(i, x, y))
|
if (next >= 0 && z >= getceilzofslope(next, x, y))
|
||||||
SET_AND_RETURN(*sectnum, i);
|
SET_AND_RETURN(*sectnum, next);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (z > fz)
|
if (z > fz)
|
||||||
{
|
{
|
||||||
i = yax_getneighborsect(x, y, *sectnum, YAX_FLOOR);
|
int const next = yax_getneighborsect(x, y, *sectnum, YAX_FLOOR);
|
||||||
if (i >= 0 && z <= getflorzofslope(i, x, y))
|
if (next >= 0 && z <= getflorzofslope(next, x, y))
|
||||||
SET_AND_RETURN(*sectnum, i);
|
SET_AND_RETURN(*sectnum, next);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (nofirstzcheck || (z >= cz && z <= fz))
|
if (nofirstzcheck || (z >= cz && z <= fz))
|
||||||
if (inside_p(x, y, *sectnum))
|
if (inside_p(x, y, *sectnum))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
wal = (uwalltype *)&wall[sector[*sectnum].wallptr];
|
uwalltype const * wal = (uwalltype *)&wall[sector[*sectnum].wallptr];
|
||||||
j = sector[*sectnum].wallnum;
|
int wallsleft = sector[*sectnum].wallnum;
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
// YAX: TODO: check neighboring sectors here too?
|
// YAX: TODO: check neighboring sectors here too?
|
||||||
i = wal->nextsector;
|
int const next = wal->nextsector;
|
||||||
if (i>=0 && inside_z_p(x,y,z, i))
|
if (next>=0 && inside_z_p(x,y,z, next))
|
||||||
SET_AND_RETURN(*sectnum, i);
|
SET_AND_RETURN(*sectnum, next);
|
||||||
|
|
||||||
wal++; j--;
|
wal++;
|
||||||
}
|
}
|
||||||
while (j != 0);
|
while (--wallsleft);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i=numsectors-1; i>=0; i--)
|
for (int i=numsectors-1; i>=0; --i)
|
||||||
if (inside_z_p(x,y,z, i))
|
if (inside_z_p(x,y,z, i))
|
||||||
SET_AND_RETURN(*sectnum, i);
|
SET_AND_RETURN(*sectnum, i);
|
||||||
|
|
||||||
|
@ -11505,7 +11494,6 @@ void getzrange(const vec3_t *pos, int16_t sectnum,
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t clipsectcnt = 0;
|
int32_t clipsectcnt = 0;
|
||||||
int32_t daz, daz2, i, j, x1, y1, x2, y2;
|
|
||||||
|
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
// YAX round, -1:center, 0:ceiling, 1:floor
|
// YAX round, -1:center, 0:ceiling, 1:floor
|
||||||
|
@ -11566,15 +11554,16 @@ restart_grand:
|
||||||
|
|
||||||
clipsprite_initindex(curidx, curspr, &clipsectcnt, pos);
|
clipsprite_initindex(curidx, curspr, &clipsectcnt, pos);
|
||||||
|
|
||||||
for (i=0; i<clipsectnum; i++)
|
for (int i=0; i<clipsectnum; i++)
|
||||||
{
|
{
|
||||||
const int k = clipsectorlist[i];
|
int const k = clipsectorlist[i];
|
||||||
|
|
||||||
if (k==sectq[clipinfo[curidx].qend])
|
if (k==sectq[clipinfo[curidx].qend])
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
int32_t fz, cz;
|
int32_t daz, daz2;
|
||||||
getzsofslope(k,pos->x,pos->y,&daz,&daz2);
|
getzsofslope(k,pos->x,pos->y,&daz,&daz2);
|
||||||
|
int32_t fz, cz;
|
||||||
getzsofslope(sectq[clipinfo[curidx].qend],pos->x,pos->y,&cz,&fz);
|
getzsofslope(sectq[clipinfo[curidx].qend],pos->x,pos->y,&cz,&fz);
|
||||||
const int hitwhat = (curspr-(uspritetype *)sprite)+49152;
|
const int hitwhat = (curspr-(uspritetype *)sprite)+49152;
|
||||||
|
|
||||||
|
@ -11597,25 +11586,26 @@ restart_grand:
|
||||||
const int startwall = startsec->wallptr;
|
const int startwall = startsec->wallptr;
|
||||||
const int endwall = startwall + startsec->wallnum;
|
const int endwall = startwall + startsec->wallnum;
|
||||||
|
|
||||||
for (j=startwall; j<endwall; j++)
|
for (int j=startwall; j<endwall; j++)
|
||||||
{
|
{
|
||||||
const int k = wall[j].nextsector;
|
const int k = wall[j].nextsector;
|
||||||
|
|
||||||
if (k >= 0)
|
if (k >= 0)
|
||||||
{
|
{
|
||||||
x1 = wall[j].x; x2 = wall[wall[j].point2].x;
|
vec2_t const v1 = *(vec2_t *)&wall[j];
|
||||||
if ((x1 < xmin) && (x2 < xmin)) continue;
|
vec2_t const v2 = *(vec2_t *)&wall[wall[j].point2];
|
||||||
if ((x1 > xmax) && (x2 > xmax)) continue;
|
|
||||||
y1 = wall[j].y; y2 = wall[wall[j].point2].y;
|
|
||||||
if ((y1 < ymin) && (y2 < ymin)) continue;
|
|
||||||
if ((y1 > ymax) && (y2 > ymax)) continue;
|
|
||||||
|
|
||||||
const int32_t dx = x2-x1, dy = y2-y1;
|
if ((v1.x < xmin && (v2.x < xmin)) || (v1.x > xmax && v2.x > xmax) ||
|
||||||
if (dx*(pos->y-y1) < (pos->x-x1)*dy) continue; //back
|
(v1.y < ymin && (v2.y < ymin)) || (v1.y > ymax && v2.y > ymax))
|
||||||
|
continue;
|
||||||
|
|
||||||
int32_t dax = (dx > 0) ? dx*(ymin-y1) : dx*(ymax-y1);
|
vec2_t const d = { v2.x-v1.x, v2.y-v1.y };
|
||||||
int32_t day = (dy > 0) ? dy*(xmax-x1) : dy*(xmin-x1);
|
if (d.x*(pos->y-v1.y) < (pos->x-v1.x)*d.y) continue; //back
|
||||||
if (dax >= day)
|
|
||||||
|
vec2_t da = { (d.x > 0) ? d.x*(ymin-v1.y) : d.x*(ymax-v1.y),
|
||||||
|
(d.y > 0) ? d.y*(xmax-v1.x) : d.y*(xmin-v1.x) };
|
||||||
|
|
||||||
|
if (da.x >= da.y)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (wall[j].cstat&dawalclipmask) continue; // XXX?
|
if (wall[j].cstat&dawalclipmask) continue; // XXX?
|
||||||
|
@ -11637,24 +11627,28 @@ restart_grand:
|
||||||
if (((sec->floorstat&1) == 0) && (pos->z >= sec->floorz-(3<<8))) continue;
|
if (((sec->floorstat&1) == 0) && (pos->z >= sec->floorz-(3<<8))) continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i=clipsectnum-1; i>=0; i--)
|
int i;
|
||||||
|
for (i=clipsectnum-1; i>=0; --i)
|
||||||
if (clipsectorlist[i] == k) break;
|
if (clipsectorlist[i] == k) break;
|
||||||
|
|
||||||
if (i < 0) clipsectorlist[clipsectnum++] = k;
|
if (i < 0) clipsectorlist[clipsectnum++] = k;
|
||||||
|
|
||||||
if ((x1 < xmin+MAXCLIPDIST) && (x2 < xmin+MAXCLIPDIST)) continue;
|
if (((v1.x < xmin + MAXCLIPDIST) && (v2.x < xmin + MAXCLIPDIST)) ||
|
||||||
if ((x1 > xmax-MAXCLIPDIST) && (x2 > xmax-MAXCLIPDIST)) continue;
|
((v1.x > xmax - MAXCLIPDIST) && (v2.x > xmax - MAXCLIPDIST)) ||
|
||||||
if ((y1 < ymin+MAXCLIPDIST) && (y2 < ymin+MAXCLIPDIST)) continue;
|
((v1.y < ymin + MAXCLIPDIST) && (v2.y < ymin + MAXCLIPDIST)) ||
|
||||||
if ((y1 > ymax-MAXCLIPDIST) && (y2 > ymax-MAXCLIPDIST)) continue;
|
((v1.y > ymax - MAXCLIPDIST) && (v2.y > ymax - MAXCLIPDIST)))
|
||||||
|
continue;
|
||||||
|
|
||||||
if (dx > 0) dax += dx*MAXCLIPDIST; else dax -= dx*MAXCLIPDIST;
|
if (d.x > 0) da.x += d.x*MAXCLIPDIST; else da.x -= d.x*MAXCLIPDIST;
|
||||||
if (dy > 0) day -= dy*MAXCLIPDIST; else day += dy*MAXCLIPDIST;
|
if (d.y > 0) da.y -= d.y*MAXCLIPDIST; else da.y += d.y*MAXCLIPDIST;
|
||||||
if (dax >= day)
|
if (da.x >= da.y)
|
||||||
continue;
|
continue;
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
if (mcf==-1 && curspr==NULL)
|
if (mcf==-1 && curspr==NULL)
|
||||||
origclipsectorlist[origclipsectnum++] = k;
|
origclipsectorlist[origclipsectnum++] = k;
|
||||||
#endif
|
#endif
|
||||||
//It actually got here, through all the continue's!!!
|
//It actually got here, through all the continue's!!!
|
||||||
|
int32_t daz, daz2;
|
||||||
getzsofslope(k, pos->x,pos->y, &daz,&daz2);
|
getzsofslope(k, pos->x,pos->y, &daz,&daz2);
|
||||||
|
|
||||||
#ifdef HAVE_CLIPSHAPE_FEATURE
|
#ifdef HAVE_CLIPSHAPE_FEATURE
|
||||||
|
@ -11709,14 +11703,15 @@ restart_grand:
|
||||||
|
|
||||||
////////// Sprites //////////
|
////////// Sprites //////////
|
||||||
|
|
||||||
for (i=0; i<clipsectnum; i++)
|
for (int i=0; i<clipsectnum; i++)
|
||||||
{
|
{
|
||||||
if (dasprclipmask==0)
|
if (dasprclipmask==0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
for (j=headspritesect[clipsectorlist[i]]; j>=0; j=nextspritesect[j])
|
for (int j=headspritesect[clipsectorlist[i]]; j>=0; j=nextspritesect[j])
|
||||||
{
|
{
|
||||||
const int32_t cstat = sprite[j].cstat;
|
const int32_t cstat = sprite[j].cstat;
|
||||||
|
int32_t daz, daz2;
|
||||||
|
|
||||||
if (cstat&dasprclipmask)
|
if (cstat&dasprclipmask)
|
||||||
{
|
{
|
||||||
|
@ -11726,14 +11721,14 @@ restart_grand:
|
||||||
if (clipsprite_try((uspritetype *)&sprite[j], xmin,ymin, xmax,ymax))
|
if (clipsprite_try((uspritetype *)&sprite[j], xmin,ymin, xmax,ymax))
|
||||||
continue;
|
continue;
|
||||||
#endif
|
#endif
|
||||||
x1 = sprite[j].x; y1 = sprite[j].y;
|
vec2_t v1 = *(vec2_t *)&sprite[j];
|
||||||
|
|
||||||
switch (cstat&48)
|
switch (cstat&48)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
{
|
{
|
||||||
int32_t k = walldist+(sprite[j].clipdist<<2)+1;
|
int32_t k = walldist+(sprite[j].clipdist<<2)+1;
|
||||||
if ((klabs(x1-pos->x) <= k) && (klabs(y1-pos->y) <= k))
|
if ((klabs(v1.x-pos->x) <= k) && (klabs(v1.y-pos->y) <= k))
|
||||||
{
|
{
|
||||||
daz = sprite[j].z + spriteheightofs(j, &k, 1);
|
daz = sprite[j].z + spriteheightofs(j, &k, 1);
|
||||||
daz2 = daz - k;
|
daz2 = daz - k;
|
||||||
|
@ -11744,9 +11739,10 @@ restart_grand:
|
||||||
|
|
||||||
case 16:
|
case 16:
|
||||||
{
|
{
|
||||||
get_wallspr_points((uspritetype *)&sprite[j], &x1, &x2, &y1, &y2);
|
vec2_t v2;
|
||||||
|
get_wallspr_points((uspritetype *)&sprite[j], &v1.x, &v2.x, &v1.y, &v2.y);
|
||||||
|
|
||||||
if (clipinsideboxline(pos->x,pos->y,x1,y1,x2,y2,walldist+1) != 0)
|
if (clipinsideboxline(pos->x,pos->y,v1.x,v1.y,v2.x,v2.y,walldist+1) != 0)
|
||||||
{
|
{
|
||||||
int32_t k;
|
int32_t k;
|
||||||
daz = sprite[j].z + spriteheightofs(j, &k, 1);
|
daz = sprite[j].z + spriteheightofs(j, &k, 1);
|
||||||
|
@ -11758,24 +11754,22 @@ restart_grand:
|
||||||
|
|
||||||
case 32:
|
case 32:
|
||||||
{
|
{
|
||||||
int32_t x3, y3, x4, y4;
|
|
||||||
|
|
||||||
daz = sprite[j].z; daz2 = daz;
|
daz = sprite[j].z; daz2 = daz;
|
||||||
|
|
||||||
if ((cstat&64) != 0)
|
if ((cstat&64) != 0 && (pos->z > daz) == ((cstat&8)==0))
|
||||||
if ((pos->z > daz) == ((cstat&8)==0))
|
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
get_floorspr_points((uspritetype const *) &sprite[j], pos->x, pos->y, &x1, &x2, &x3, &x4,
|
vec2_t v2, v3, v4;
|
||||||
&y1, &y2, &y3, &y4);
|
get_floorspr_points((uspritetype const *) &sprite[j], pos->x, pos->y, &v1.x, &v2.x, &v3.x, &v4.x,
|
||||||
|
&v1.y, &v2.y, &v3.y, &v4.y);
|
||||||
|
|
||||||
vec2_t const da = { mulscale14(sintable[(sprite[j].ang - 256 + 512) & 2047], walldist + 4),
|
vec2_t const da = { mulscale14(sintable[(sprite[j].ang - 256 + 512) & 2047], walldist + 4),
|
||||||
mulscale14(sintable[(sprite[j].ang - 256) & 2047], walldist + 4) };
|
mulscale14(sintable[(sprite[j].ang - 256) & 2047], walldist + 4) };
|
||||||
|
|
||||||
x1 += da.x; x2 -= da.y; x3 -= da.x; x4 += da.y;
|
v1.x += da.x; v2.x -= da.y; v3.x -= da.x; v4.x += da.y;
|
||||||
y1 += da.y; y2 += da.x; y3 -= da.y; y4 -= da.x;
|
v1.y += da.y; v2.y += da.x; v3.y -= da.y; v4.y -= da.x;
|
||||||
|
|
||||||
clipyou = get_floorspr_clipyou(x1, x2, x3, x4, y1, y2, y3, y4);
|
clipyou = get_floorspr_clipyou(v1.x, v2.x, v3.x, v4.x, v1.y, v2.y, v3.y, v4.y);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -11815,20 +11809,21 @@ restart_grand:
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
if (numyaxbunches > 0)
|
if (numyaxbunches > 0)
|
||||||
{
|
{
|
||||||
const int32_t dasecclipmask = yax_waltosecmask(dawalclipmask);
|
int const dasecclipmask = yax_waltosecmask(dawalclipmask);
|
||||||
int16_t cb, fb, didchange;
|
int16_t cb, fb;
|
||||||
|
|
||||||
yax_getbunches(sectnum, &cb, &fb);
|
yax_getbunches(sectnum, &cb, &fb);
|
||||||
|
|
||||||
mcf++;
|
mcf++;
|
||||||
clipsectcnt = 0; clipsectnum = 0;
|
clipsectcnt = 0; clipsectnum = 0;
|
||||||
|
|
||||||
didchange = 0;
|
int didchange = 0;
|
||||||
if (cb>=0 && mcf==0 && *ceilhit==sectnum+16384)
|
if (cb>=0 && mcf==0 && *ceilhit==sectnum+16384)
|
||||||
{
|
{
|
||||||
|
int i;
|
||||||
for (i=0; i<origclipsectnum; i++)
|
for (i=0; i<origclipsectnum; i++)
|
||||||
{
|
{
|
||||||
j = origclipsectorlist[i];
|
int const j = origclipsectorlist[i];
|
||||||
if (yax_getbunch(j, YAX_CEILING) >= 0)
|
if (yax_getbunch(j, YAX_CEILING) >= 0)
|
||||||
if (sector[j].ceilingstat&dasecclipmask)
|
if (sector[j].ceilingstat&dasecclipmask)
|
||||||
break;
|
break;
|
||||||
|
@ -11841,11 +11836,11 @@ restart_grand:
|
||||||
if (cb < 0)
|
if (cb < 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
for (SECTORS_OF_BUNCH(cb,YAX_FLOOR, j))
|
for (int SECTORS_OF_BUNCH(cb,YAX_FLOOR, j))
|
||||||
if (inside(pos->x,pos->y, j)==1)
|
if (inside(pos->x,pos->y, j)==1)
|
||||||
{
|
{
|
||||||
clipsectorlist[clipsectnum++] = j;
|
clipsectorlist[clipsectnum++] = j;
|
||||||
daz = getceilzofslope(j, pos->x,pos->y);
|
int const daz = getceilzofslope(j, pos->x,pos->y);
|
||||||
if (!didchange || daz > *ceilz)
|
if (!didchange || daz > *ceilz)
|
||||||
didchange=1, *ceilhit = j+16384, *ceilz = daz;
|
didchange=1, *ceilhit = j+16384, *ceilz = daz;
|
||||||
}
|
}
|
||||||
|
@ -11860,9 +11855,10 @@ restart_grand:
|
||||||
didchange = 0;
|
didchange = 0;
|
||||||
if (fb>=0 && mcf==1 && *florhit==sectnum+16384)
|
if (fb>=0 && mcf==1 && *florhit==sectnum+16384)
|
||||||
{
|
{
|
||||||
for (i=0; i<origclipsectnum; i++)
|
int i=0;
|
||||||
|
for (; i<origclipsectnum; i++)
|
||||||
{
|
{
|
||||||
j = origclipsectorlist[i];
|
int const j = origclipsectorlist[i];
|
||||||
if (yax_getbunch(j, YAX_FLOOR) >= 0)
|
if (yax_getbunch(j, YAX_FLOOR) >= 0)
|
||||||
if (sector[j].floorstat&dasecclipmask)
|
if (sector[j].floorstat&dasecclipmask)
|
||||||
break;
|
break;
|
||||||
|
@ -11876,11 +11872,11 @@ restart_grand:
|
||||||
if (fb < 0)
|
if (fb < 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
for (SECTORS_OF_BUNCH(fb, YAX_CEILING, j))
|
for (int SECTORS_OF_BUNCH(fb, YAX_CEILING, j))
|
||||||
if (inside(pos->x,pos->y, j)==1)
|
if (inside(pos->x,pos->y, j)==1)
|
||||||
{
|
{
|
||||||
clipsectorlist[clipsectnum++] = j;
|
clipsectorlist[clipsectnum++] = j;
|
||||||
daz = getflorzofslope(j, pos->x,pos->y);
|
int const daz = getflorzofslope(j, pos->x,pos->y);
|
||||||
if (!didchange || daz < *florz)
|
if (!didchange || daz < *florz)
|
||||||
didchange=1, *florhit = j+16384, *florz = daz;
|
didchange=1, *florhit = j+16384, *florz = daz;
|
||||||
}
|
}
|
||||||
|
@ -11955,8 +11951,6 @@ void setaspect_new()
|
||||||
//
|
//
|
||||||
void setview(int32_t x1, int32_t y1, int32_t x2, int32_t y2)
|
void setview(int32_t x1, int32_t y1, int32_t x2, int32_t y2)
|
||||||
{
|
{
|
||||||
int32_t i;
|
|
||||||
|
|
||||||
windowxy1.x = x1; wx1 = (x1<<12);
|
windowxy1.x = x1; wx1 = (x1<<12);
|
||||||
windowxy1.y = y1; wy1 = (y1<<12);
|
windowxy1.y = y1; wy1 = (y1<<12);
|
||||||
windowxy2.x = x2; wx2 = ((x2+1)<<12);
|
windowxy2.x = x2; wx2 = ((x2+1)<<12);
|
||||||
|
@ -11972,11 +11966,11 @@ void setview(int32_t x1, int32_t y1, int32_t x2, int32_t y2)
|
||||||
#endif
|
#endif
|
||||||
setaspect_new();
|
setaspect_new();
|
||||||
|
|
||||||
for (i=0; i<windowxy1.x; i++) { startumost[i] = 1, startdmost[i] = 0; }
|
for (int i=0; i<windowxy1.x; i++) { startumost[i] = 1, startdmost[i] = 0; }
|
||||||
Bassert(windowxy2.x < xdim); // xdim is the number of alloc'd elements in start*most[].
|
Bassert(windowxy2.x < xdim); // xdim is the number of alloc'd elements in start*most[].
|
||||||
for (i=windowxy1.x; i<=windowxy2.x; i++)
|
for (int i=windowxy1.x; i<=windowxy2.x; i++)
|
||||||
{ startumost[i] = windowxy1.y, startdmost[i] = windowxy2.y+1; }
|
{ startumost[i] = windowxy1.y, startdmost[i] = windowxy2.y+1; }
|
||||||
for (i=windowxy2.x+1; i<xdim; i++) { startumost[i] = 1, startdmost[i] = 0; }
|
for (int i=windowxy2.x+1; i<xdim; i++) { startumost[i] = 1, startdmost[i] = 0; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -12106,9 +12100,6 @@ void rotatesprite_(int32_t sx, int32_t sy, int32_t z, int16_t a, int16_t picnum,
|
||||||
//
|
//
|
||||||
void clearview(int32_t dacol)
|
void clearview(int32_t dacol)
|
||||||
{
|
{
|
||||||
intptr_t p;
|
|
||||||
int32_t y, dx;
|
|
||||||
|
|
||||||
if (!in3dmode() && dacol != -1) return;
|
if (!in3dmode() && dacol != -1) return;
|
||||||
|
|
||||||
if (dacol == -1) dacol = 0;
|
if (dacol == -1) dacol = 0;
|
||||||
|
@ -12116,7 +12107,7 @@ void clearview(int32_t dacol)
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
if (getrendermode() >= REND_POLYMOST)
|
if (getrendermode() >= REND_POLYMOST)
|
||||||
{
|
{
|
||||||
palette_t p = getpal(dacol);
|
palette_t const p = getpal(dacol);
|
||||||
|
|
||||||
bglClearColor((float)p.r * (1.f/255.f),
|
bglClearColor((float)p.r * (1.f/255.f),
|
||||||
(float)p.g * (1.f/255.f),
|
(float)p.g * (1.f/255.f),
|
||||||
|
@ -12128,10 +12119,10 @@ void clearview(int32_t dacol)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
begindrawing(); //{{{
|
begindrawing(); //{{{
|
||||||
dx = windowxy2.x-windowxy1.x+1;
|
|
||||||
//dacol += (dacol<<8); dacol += (dacol<<16);
|
//dacol += (dacol<<8); dacol += (dacol<<16);
|
||||||
p = frameplace+ylookup[windowxy1.y]+windowxy1.x;
|
int const dx = windowxy2.x-windowxy1.x+1;
|
||||||
for (y=windowxy1.y; y<=windowxy2.y; y++)
|
intptr_t p = frameplace+ylookup[windowxy1.y]+windowxy1.x;
|
||||||
|
for (int y=windowxy1.y; y<=windowxy2.y; ++y)
|
||||||
{
|
{
|
||||||
//clearbufbyte((void*)p,dx,dacol);
|
//clearbufbyte((void*)p,dx,dacol);
|
||||||
Bmemset((void *)p,dacol,dx);
|
Bmemset((void *)p,dacol,dx);
|
||||||
|
@ -12154,7 +12145,7 @@ void clearallviews(int32_t dacol)
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
if (getrendermode() >= REND_POLYMOST)
|
if (getrendermode() >= REND_POLYMOST)
|
||||||
{
|
{
|
||||||
palette_t p = getpal(dacol);
|
palette_t const p = getpal(dacol);
|
||||||
|
|
||||||
bglViewport(0,0,xdim,ydim); glox1 = -1;
|
bglViewport(0,0,xdim,ydim); glox1 = -1;
|
||||||
bglClearColor((float)p.r * (1.f/255.f),
|
bglClearColor((float)p.r * (1.f/255.f),
|
||||||
|
@ -12186,8 +12177,8 @@ void setviewtotile(int16_t tilenume, int32_t xsiz, int32_t ysiz)
|
||||||
tilesiz[tilenume].x = xsiz; tilesiz[tilenume].y = ysiz;
|
tilesiz[tilenume].x = xsiz; tilesiz[tilenume].y = ysiz;
|
||||||
bakxsiz[setviewcnt] = xsiz; bakysiz[setviewcnt] = ysiz;
|
bakxsiz[setviewcnt] = xsiz; bakysiz[setviewcnt] = ysiz;
|
||||||
bakframeplace[setviewcnt] = frameplace; frameplace = waloff[tilenume];
|
bakframeplace[setviewcnt] = frameplace; frameplace = waloff[tilenume];
|
||||||
bakwindowx1[setviewcnt] = windowxy1.x; bakwindowy1[setviewcnt] = windowxy1.y;
|
bakwindowxy1[setviewcnt] = windowxy1;
|
||||||
bakwindowx2[setviewcnt] = windowxy2.x; bakwindowy2[setviewcnt] = windowxy2.y;
|
bakwindowxy2[setviewcnt] = windowxy2;
|
||||||
|
|
||||||
if (setviewcnt == 0)
|
if (setviewcnt == 0)
|
||||||
{
|
{
|
||||||
|
@ -12230,8 +12221,8 @@ void setviewback(void)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
setview(bakwindowx1[setviewcnt],bakwindowy1[setviewcnt],
|
setview(bakwindowxy1[setviewcnt].x,bakwindowxy1[setviewcnt].y,
|
||||||
bakwindowx2[setviewcnt],bakwindowy2[setviewcnt]);
|
bakwindowxy2[setviewcnt].x,bakwindowxy2[setviewcnt].y);
|
||||||
copybufbyte(&bakumost[windowxy1.x],&startumost[windowxy1.x],(windowxy2.x-windowxy1.x+1)*sizeof(startumost[0]));
|
copybufbyte(&bakumost[windowxy1.x],&startumost[windowxy1.x],(windowxy2.x-windowxy1.x+1)*sizeof(startumost[0]));
|
||||||
copybufbyte(&bakdmost[windowxy1.x],&startdmost[windowxy1.x],(windowxy2.x-windowxy1.x+1)*sizeof(startdmost[0]));
|
copybufbyte(&bakdmost[windowxy1.x],&startdmost[windowxy1.x],(windowxy2.x-windowxy1.x+1)*sizeof(startdmost[0]));
|
||||||
frameplace = bakframeplace[setviewcnt];
|
frameplace = bakframeplace[setviewcnt];
|
||||||
|
@ -12248,7 +12239,7 @@ void setviewback(void)
|
||||||
//
|
//
|
||||||
void squarerotatetile(int16_t tilenume)
|
void squarerotatetile(int16_t tilenume)
|
||||||
{
|
{
|
||||||
int32_t siz = tilesiz[tilenume].x;
|
int const siz = tilesiz[tilenume].x;
|
||||||
|
|
||||||
if (siz != tilesiz[tilenume].y)
|
if (siz != tilesiz[tilenume].y)
|
||||||
return;
|
return;
|
||||||
|
@ -12259,21 +12250,23 @@ void squarerotatetile(int16_t tilenume)
|
||||||
{
|
{
|
||||||
ptr2 = ptr1 = (char *) (waloff[tilenume]+i*(siz+1));
|
ptr2 = ptr1 = (char *) (waloff[tilenume]+i*(siz+1));
|
||||||
swapchar(--ptr1, (ptr2 -= siz));
|
swapchar(--ptr1, (ptr2 -= siz));
|
||||||
j=(i>>1)-1;
|
for (j=(i>>1)-1; j>=0; --j)
|
||||||
for (; j>=0; j--) swapchar2((ptr1 -= 2), (ptr2 -= (siz<<1)), siz);
|
swapchar2((ptr1 -= 2), (ptr2 -= (siz<<1)), siz);
|
||||||
|
|
||||||
ptr2 = ptr1 = (char *) (waloff[tilenume]+(i-1)*(siz+1));
|
ptr2 = ptr1 = (char *) (waloff[tilenume]+(i-1)*(siz+1));
|
||||||
j=((i-1)>>1)-1;
|
for (j=((i-1)>>1)-1; j>=0; --j)
|
||||||
for (; j>=0; j--) swapchar2((ptr1 -= 2), (ptr2 -= (siz<<1)), siz);
|
swapchar2((ptr1 -= 2), (ptr2 -= (siz<<1)), siz);
|
||||||
|
|
||||||
ptr2 = ptr1 = (char *) (waloff[tilenume]+(i-2)*(siz+1));
|
ptr2 = ptr1 = (char *) (waloff[tilenume]+(i-2)*(siz+1));
|
||||||
swapchar(--ptr1, (ptr2 -= siz));
|
swapchar(--ptr1, (ptr2 -= siz));
|
||||||
j=((i-2)>>1)-1;
|
|
||||||
for (; j>=0; j--) swapchar2((ptr1 -= 2), (ptr2 -= (siz<<1)), siz);
|
for (j=((i-2)>>1)-1; j>=0; --j)
|
||||||
|
swapchar2((ptr1 -= 2), (ptr2 -= (siz<<1)), siz);
|
||||||
|
|
||||||
ptr2 = ptr1 = (char *) (waloff[tilenume]+(i-3)*(siz+1));
|
ptr2 = ptr1 = (char *) (waloff[tilenume]+(i-3)*(siz+1));
|
||||||
j=((i-3)>>1)-1;
|
|
||||||
for (; j>=0; j--) swapchar2((ptr1 -= 2), (ptr2 -= (siz<<1)), siz);
|
for (j=((i-3)>>1)-1; j>=0; --j)
|
||||||
|
swapchar2((ptr1 -= 2), (ptr2 -= (siz<<1)), siz);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -12330,16 +12323,16 @@ void completemirror(void)
|
||||||
begindrawing();
|
begindrawing();
|
||||||
|
|
||||||
// Width in pixels (screen x's are inclusive on both sides):
|
// Width in pixels (screen x's are inclusive on both sides):
|
||||||
const int32_t width = mirrorsx2-mirrorsx1+1;
|
int const width = mirrorsx2-mirrorsx1+1;
|
||||||
// Height in pixels (screen y's are half-open because they come from umost/dmost):
|
// Height in pixels (screen y's are half-open because they come from umost/dmost):
|
||||||
const int32_t height = mirrorsy2-mirrorsy1;
|
int const height = mirrorsy2-mirrorsy1;
|
||||||
|
|
||||||
// Address of the mirror wall's top left corner in the source scene:
|
// Address of the mirror wall's top left corner in the source scene:
|
||||||
intptr_t p = frameplace + ylookup[windowxy1.y+mirrorsy1] + windowxy1.x+mirrorsx1;
|
intptr_t p = frameplace + ylookup[windowxy1.y+mirrorsy1] + windowxy1.x+mirrorsx1;
|
||||||
|
|
||||||
// Offset (wrt p) of a mirror line's left corner in the destination:
|
// Offset (wrt p) of a mirror line's left corner in the destination:
|
||||||
// p+destof == frameplace + ylookup[...] + windowx2-mirrorsx2
|
// p+destof == frameplace + ylookup[...] + windowx2-mirrorsx2
|
||||||
const int32_t destofs = windowxy2.x-mirrorsx2-windowxy1.x-mirrorsx1;
|
int const destofs = windowxy2.x-mirrorsx2-windowxy1.x-mirrorsx1;
|
||||||
|
|
||||||
for (int y=0; y<height; y++)
|
for (int y=0; y<height; y++)
|
||||||
{
|
{
|
||||||
|
@ -12397,7 +12390,7 @@ int32_t sectorofwall_noquick(int16_t theline)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int32_t getceilzofslopeptr(const sectortype *sec, int32_t dax, int32_t day)
|
int32_t getceilzofslopeptr(const usectortype *sec, int32_t dax, int32_t day)
|
||||||
{
|
{
|
||||||
if (!(sec->ceilingstat&2))
|
if (!(sec->ceilingstat&2))
|
||||||
return sec->ceilingz;
|
return sec->ceilingz;
|
||||||
|
@ -12408,14 +12401,14 @@ int32_t getceilzofslopeptr(const sectortype *sec, int32_t dax, int32_t day)
|
||||||
vec2_t const w = *(vec2_t const *)wal;
|
vec2_t const w = *(vec2_t const *)wal;
|
||||||
vec2_t const d = { wall[wal->point2].x-w.x , wall[wal->point2].y-w.y };
|
vec2_t const d = { wall[wal->point2].x-w.x , wall[wal->point2].y-w.y };
|
||||||
|
|
||||||
int32_t const i = nsqrtasm(uhypsq(d.x,d.y))<<5;
|
int const i = nsqrtasm(uhypsq(d.x,d.y))<<5;
|
||||||
if (i == 0) return sec->ceilingz;
|
if (i == 0) return sec->ceilingz;
|
||||||
|
|
||||||
int32_t const j = dmulscale3(d.x, day-w.y, -d.y, dax-w.x);
|
int const j = dmulscale3(d.x, day-w.y, -d.y, dax-w.x);
|
||||||
return sec->ceilingz + (scale(sec->ceilingheinum,j>>1,i)<<1);
|
return sec->ceilingz + (scale(sec->ceilingheinum,j>>1,i)<<1);
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t getflorzofslopeptr(const sectortype *sec, int32_t dax, int32_t day)
|
int32_t getflorzofslopeptr(const usectortype *sec, int32_t dax, int32_t day)
|
||||||
{
|
{
|
||||||
if (!(sec->floorstat&2))
|
if (!(sec->floorstat&2))
|
||||||
return sec->floorz;
|
return sec->floorz;
|
||||||
|
@ -12425,14 +12418,14 @@ int32_t getflorzofslopeptr(const sectortype *sec, int32_t dax, int32_t day)
|
||||||
vec2_t const w = *(vec2_t const *)wal;
|
vec2_t const w = *(vec2_t const *)wal;
|
||||||
vec2_t const d = { wall[wal->point2].x-w.x , wall[wal->point2].y-w.y };
|
vec2_t const d = { wall[wal->point2].x-w.x , wall[wal->point2].y-w.y };
|
||||||
|
|
||||||
int32_t const i = nsqrtasm(uhypsq(d.x,d.y))<<5;
|
int const i = nsqrtasm(uhypsq(d.x,d.y))<<5;
|
||||||
if (i == 0) return sec->floorz;
|
if (i == 0) return sec->floorz;
|
||||||
|
|
||||||
int32_t const j = dmulscale3(d.x, day-w.y, -d.y, dax-w.x);
|
int const j = dmulscale3(d.x, day-w.y, -d.y, dax-w.x);
|
||||||
return sec->floorz + (scale(sec->floorheinum,j>>1,i)<<1);
|
return sec->floorz + (scale(sec->floorheinum,j>>1,i)<<1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void getzsofslopeptr(const sectortype *sec, int32_t dax, int32_t day, int32_t *ceilz, int32_t *florz)
|
void getzsofslopeptr(const usectortype *sec, int32_t dax, int32_t day, int32_t *ceilz, int32_t *florz)
|
||||||
{
|
{
|
||||||
*ceilz = sec->ceilingz; *florz = sec->floorz;
|
*ceilz = sec->ceilingz; *florz = sec->floorz;
|
||||||
|
|
||||||
|
@ -12441,12 +12434,12 @@ void getzsofslopeptr(const sectortype *sec, int32_t dax, int32_t day, int32_t *c
|
||||||
|
|
||||||
uwalltype const *wal = (uwalltype *) &wall[sec->wallptr];
|
uwalltype const *wal = (uwalltype *) &wall[sec->wallptr];
|
||||||
uwalltype const *wal2 = (uwalltype *) &wall[wal->point2];
|
uwalltype const *wal2 = (uwalltype *) &wall[wal->point2];
|
||||||
const vec2_t d ={ wal2->x-wal->x, wal2->y-wal->y };
|
vec2_t const d = { wal2->x-wal->x, wal2->y-wal->y };
|
||||||
|
|
||||||
int32_t const i = nsqrtasm(uhypsq(d.x,d.y))<<5;
|
int const i = nsqrtasm(uhypsq(d.x,d.y))<<5;
|
||||||
if (i == 0) return;
|
if (i == 0) return;
|
||||||
|
|
||||||
int32_t const j = dmulscale3(d.x,day-wal->y, -d.y,dax-wal->x);
|
int const j = dmulscale3(d.x,day-wal->y, -d.y,dax-wal->x);
|
||||||
if (sec->ceilingstat&2)
|
if (sec->ceilingstat&2)
|
||||||
*ceilz += scale(sec->ceilingheinum,j>>1,i)<<1;
|
*ceilz += scale(sec->ceilingheinum,j>>1,i)<<1;
|
||||||
if (sec->floorstat&2)
|
if (sec->floorstat&2)
|
||||||
|
|
|
@ -79,8 +79,6 @@ static inline void ALLOC_MAPART_ARRAY(origar_t &origar, bakar_t &bakar)
|
||||||
|
|
||||||
void E_MapArt_Clear(void)
|
void E_MapArt_Clear(void)
|
||||||
{
|
{
|
||||||
int32_t i;
|
|
||||||
|
|
||||||
if (g_bakTileFileNum == NULL)
|
if (g_bakTileFileNum == NULL)
|
||||||
return; // per-map ART N/A
|
return; // per-map ART N/A
|
||||||
|
|
||||||
|
@ -95,13 +93,15 @@ void E_MapArt_Clear(void)
|
||||||
artfilplc = 0L;
|
artfilplc = 0L;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i=0; i<MAXTILES; i++)
|
for (int i=0; i<MAXTILES; i++)
|
||||||
|
{
|
||||||
if (tilefilenum[i] >= MAXARTFILES_BASE)
|
if (tilefilenum[i] >= MAXARTFILES_BASE)
|
||||||
{
|
{
|
||||||
// XXX: OK way to free it? Better: cache1d API. CACHE1D_FREE
|
// XXX: OK way to free it? Better: cache1d API. CACHE1D_FREE
|
||||||
walock[i] = 1;
|
walock[i] = 1;
|
||||||
waloff[i] = 0;
|
waloff[i] = 0;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Restore original per-tile arrays
|
// Restore original per-tile arrays
|
||||||
RESTORE_MAPART_ARRAY(tilefilenum, g_bakTileFileNum);
|
RESTORE_MAPART_ARRAY(tilefilenum, g_bakTileFileNum);
|
||||||
|
@ -121,8 +121,6 @@ void E_MapArt_Clear(void)
|
||||||
|
|
||||||
void E_MapArt_Setup(const char *filename)
|
void E_MapArt_Setup(const char *filename)
|
||||||
{
|
{
|
||||||
int32_t i;
|
|
||||||
|
|
||||||
E_MapArt_Clear();
|
E_MapArt_Clear();
|
||||||
|
|
||||||
if (Bstrlen(filename) + 7 >= sizeof(mapartfilename))
|
if (Bstrlen(filename) + 7 >= sizeof(mapartfilename))
|
||||||
|
@ -149,9 +147,9 @@ void E_MapArt_Setup(const char *filename)
|
||||||
ALLOC_MAPART_ARRAY(tilesiz, g_bakTileSiz);
|
ALLOC_MAPART_ARRAY(tilesiz, g_bakTileSiz);
|
||||||
ALLOC_MAPART_ARRAY(picanm, g_bakPicAnm);
|
ALLOC_MAPART_ARRAY(picanm, g_bakPicAnm);
|
||||||
|
|
||||||
for (i=MAXARTFILES_BASE; i<MAXARTFILES_TOTAL; i++)
|
for (int i=MAXARTFILES_BASE; i<MAXARTFILES_TOTAL; i++)
|
||||||
{
|
{
|
||||||
int32_t ret = E_ReadArtFileOfID(i);
|
int ret = E_ReadArtFileOfID(i);
|
||||||
|
|
||||||
if (ret != 0)
|
if (ret != 0)
|
||||||
{
|
{
|
||||||
|
@ -284,7 +282,7 @@ int32_t E_ReadArtFileHeader(int32_t const fil, char const * const fn, artheader_
|
||||||
|
|
||||||
int32_t E_ReadArtFileHeaderFromBuffer(uint8_t const * const buf, artheader_t * const local)
|
int32_t E_ReadArtFileHeaderFromBuffer(uint8_t const * const buf, artheader_t * const local)
|
||||||
{
|
{
|
||||||
int32_t const artversion = B_LITTLE32(B_UNBUF32(&buf[0]));
|
int const artversion = B_LITTLE32(B_UNBUF32(&buf[0]));
|
||||||
if (EDUKE32_PREDICT_FALSE(artversion != 1))
|
if (EDUKE32_PREDICT_FALSE(artversion != 1))
|
||||||
{
|
{
|
||||||
initprintf("loadpics: Invalid art file version\n");
|
initprintf("loadpics: Invalid art file version\n");
|
||||||
|
@ -349,7 +347,7 @@ void E_ReadArtFileTileInfo(int32_t const fil, artheader_t const * const local)
|
||||||
kread(fil, tilesizy, local->numtiles*sizeof(int16_t));
|
kread(fil, tilesizy, local->numtiles*sizeof(int16_t));
|
||||||
kread(fil, &picanm[local->tilestart], local->numtiles*sizeof(picanm_t));
|
kread(fil, &picanm[local->tilestart], local->numtiles*sizeof(picanm_t));
|
||||||
|
|
||||||
for (int32_t i=local->tilestart; i<=local->tileend; i++)
|
for (int i=local->tilestart; i<=local->tileend; i++)
|
||||||
{
|
{
|
||||||
tilesiz[i].x = B_LITTLE16(tilesizx[i-local->tilestart]);
|
tilesiz[i].x = B_LITTLE16(tilesizx[i-local->tilestart]);
|
||||||
tilesiz[i].y = B_LITTLE16(tilesizy[i-local->tilestart]);
|
tilesiz[i].y = B_LITTLE16(tilesizy[i-local->tilestart]);
|
||||||
|
@ -366,9 +364,9 @@ void E_ReadArtFileIntoFakeData(int32_t const fil, artheader_t const * const loca
|
||||||
char *buffer = NULL;
|
char *buffer = NULL;
|
||||||
int32_t buffersize = 0;
|
int32_t buffersize = 0;
|
||||||
|
|
||||||
for (int32_t i=local->tilestart; i<=local->tileend; i++)
|
for (int i=local->tilestart; i<=local->tileend; i++)
|
||||||
{
|
{
|
||||||
int32_t dasiz = tilesiz[i].x * tilesiz[i].y;
|
int const dasiz = tilesiz[i].x * tilesiz[i].y;
|
||||||
|
|
||||||
if (dasiz == 0)
|
if (dasiz == 0)
|
||||||
{
|
{
|
||||||
|
@ -377,9 +375,7 @@ void E_ReadArtFileIntoFakeData(int32_t const fil, artheader_t const * const loca
|
||||||
}
|
}
|
||||||
|
|
||||||
maybe_grow_buffer(&buffer, &buffersize, dasiz);
|
maybe_grow_buffer(&buffer, &buffersize, dasiz);
|
||||||
|
|
||||||
kread(fil, buffer, dasiz);
|
kread(fil, buffer, dasiz);
|
||||||
|
|
||||||
E_CreateFakeTile(i, dasiz, buffer);
|
E_CreateFakeTile(i, dasiz, buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -431,7 +427,7 @@ static int32_t E_ReadArtFileOfID(int32_t tilefilei)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
artheader_t local;
|
artheader_t local;
|
||||||
int32_t headerval = E_ReadArtFileHeader(fil, fn, &local);
|
int const headerval = E_ReadArtFileHeader(fil, fn, &local);
|
||||||
if (headerval != 0)
|
if (headerval != 0)
|
||||||
return headerval;
|
return headerval;
|
||||||
|
|
||||||
|
@ -465,11 +461,11 @@ static int32_t E_ReadArtFileOfID(int32_t tilefilei)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
int32_t offscount = 4+4+4+4+(local.numtiles<<3);
|
int offscount = 4+4+4+4+(local.numtiles<<3);
|
||||||
|
|
||||||
for (int32_t i=local.tilestart; i<=local.tileend; i++)
|
for (int i=local.tilestart; i<=local.tileend; ++i)
|
||||||
{
|
{
|
||||||
int32_t dasiz = tilesiz[i].x * tilesiz[i].y;
|
int const dasiz = tilesiz[i].x * tilesiz[i].y;
|
||||||
|
|
||||||
tilefilenum[i] = tilefilei;
|
tilefilenum[i] = tilefilei;
|
||||||
tilefileoffs[i] = offscount;
|
tilefileoffs[i] = offscount;
|
||||||
|
@ -495,8 +491,6 @@ static int32_t E_ReadArtFileOfID(int32_t tilefilei)
|
||||||
//
|
//
|
||||||
int32_t loadpics(const char *filename, int32_t askedsize)
|
int32_t loadpics(const char *filename, int32_t askedsize)
|
||||||
{
|
{
|
||||||
int32_t tilefilei;
|
|
||||||
|
|
||||||
Bstrncpyz(artfilename, filename, sizeof(artfilename));
|
Bstrncpyz(artfilename, filename, sizeof(artfilename));
|
||||||
|
|
||||||
Bmemset(&tilesiz[0], 0, sizeof(vec2_t) * MAXTILES);
|
Bmemset(&tilesiz[0], 0, sizeof(vec2_t) * MAXTILES);
|
||||||
|
@ -504,16 +498,13 @@ int32_t loadpics(const char *filename, int32_t askedsize)
|
||||||
|
|
||||||
// artsize = 0;
|
// artsize = 0;
|
||||||
|
|
||||||
for (tilefilei=0; tilefilei<MAXARTFILES_BASE; tilefilei++)
|
for (int tilefilei=0; tilefilei<MAXARTFILES_BASE; tilefilei++)
|
||||||
E_ReadArtFileOfID(tilefilei);
|
E_ReadArtFileOfID(tilefilei);
|
||||||
|
|
||||||
Bmemset(gotpic, 0, sizeof(gotpic));
|
Bmemset(gotpic, 0, sizeof(gotpic));
|
||||||
|
|
||||||
//cachesize = min((int32_t)((Bgetsysmemsize()/100)*60),max(artsize,askedsize));
|
//cachesize = min((int32_t)((Bgetsysmemsize()/100)*60),max(artsize,askedsize));
|
||||||
if (Bgetsysmemsize() <= (uint32_t) askedsize)
|
cachesize = (Bgetsysmemsize() <= (uint32_t)askedsize) ? (Bgetsysmemsize() / 100) * 60 : askedsize;
|
||||||
cachesize = (Bgetsysmemsize()/100)*60;
|
|
||||||
else
|
|
||||||
cachesize = askedsize;
|
|
||||||
|
|
||||||
// NOTE: this doesn't make a lot of sense on modern OSs...
|
// NOTE: this doesn't make a lot of sense on modern OSs...
|
||||||
while ((pic = Bmalloc(cachesize)) == NULL)
|
while ((pic = Bmalloc(cachesize)) == NULL)
|
||||||
|
@ -541,10 +532,9 @@ static void postloadtile(int16_t tilenume);
|
||||||
|
|
||||||
void loadtile(int16_t tilenume)
|
void loadtile(int16_t tilenume)
|
||||||
{
|
{
|
||||||
int32_t dasiz;
|
|
||||||
|
|
||||||
if ((unsigned) tilenume >= (unsigned) MAXTILES) return;
|
if ((unsigned) tilenume >= (unsigned) MAXTILES) return;
|
||||||
if ((dasiz = tilesiz[tilenume].x*tilesiz[tilenume].y) <= 0) return;
|
int const dasiz = tilesiz[tilenume].x*tilesiz[tilenume].y;
|
||||||
|
if (dasiz <= 0) return;
|
||||||
|
|
||||||
// Allocate storage if necessary.
|
// Allocate storage if necessary.
|
||||||
if (waloff[tilenume] == 0)
|
if (waloff[tilenume] == 0)
|
||||||
|
@ -571,19 +561,18 @@ void E_LoadTileIntoBuffer(int16_t tilenume, int32_t dasiz, char *buffer)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t const i = tilefilenum[tilenume];
|
int const tfn = tilefilenum[tilenume];
|
||||||
|
|
||||||
// Potentially switch open ART file.
|
// Potentially switch open ART file.
|
||||||
if (i != artfilnum)
|
if (tfn != artfilnum)
|
||||||
{
|
{
|
||||||
const char *fn;
|
|
||||||
|
|
||||||
if (artfil != -1)
|
if (artfil != -1)
|
||||||
kclose(artfil);
|
kclose(artfil);
|
||||||
|
|
||||||
fn = E_GetArtFileName(i);
|
char const *fn = E_GetArtFileName(tfn);
|
||||||
|
|
||||||
artfil = kopen4load(fn, 0);
|
artfil = kopen4load(fn, 0);
|
||||||
|
|
||||||
if (artfil == -1)
|
if (artfil == -1)
|
||||||
{
|
{
|
||||||
initprintf("Failed opening ART file \"%s\"!\n", fn);
|
initprintf("Failed opening ART file \"%s\"!\n", fn);
|
||||||
|
@ -591,7 +580,7 @@ void E_LoadTileIntoBuffer(int16_t tilenume, int32_t dasiz, char *buffer)
|
||||||
Bexit(11);
|
Bexit(11);
|
||||||
}
|
}
|
||||||
|
|
||||||
artfilnum = i;
|
artfilnum = tfn;
|
||||||
artfilplc = 0L;
|
artfilplc = 0L;
|
||||||
|
|
||||||
faketimerhandler();
|
faketimerhandler();
|
||||||
|
@ -646,16 +635,17 @@ static void postloadtile(int16_t tilenume)
|
||||||
// Assumes pic has been initialized to zero.
|
// Assumes pic has been initialized to zero.
|
||||||
void E_RenderArtDataIntoBuffer(palette_t * const pic, uint8_t const * const buf, int32_t const bufsizx, int32_t const sizx, int32_t const sizy)
|
void E_RenderArtDataIntoBuffer(palette_t * const pic, uint8_t const * const buf, int32_t const bufsizx, int32_t const sizx, int32_t const sizy)
|
||||||
{
|
{
|
||||||
for (int32_t y = 0; y < sizy; y++)
|
for (int y = 0; y < sizy; ++y)
|
||||||
{
|
{
|
||||||
palette_t * const picrow = &pic[bufsizx * y];
|
palette_t * const picrow = &pic[bufsizx * y];
|
||||||
|
|
||||||
for (int32_t x = 0; x < sizx; x++)
|
for (int x = 0; x < sizx; ++x)
|
||||||
{
|
{
|
||||||
uint8_t index = buf[sizy * x + y];
|
uint8_t index = buf[sizy * x + y];
|
||||||
|
|
||||||
if (index != 255)
|
if (index == 255)
|
||||||
{
|
continue;
|
||||||
|
|
||||||
index *= 3;
|
index *= 3;
|
||||||
|
|
||||||
// pic is BGRA
|
// pic is BGRA
|
||||||
|
@ -666,19 +656,16 @@ void E_RenderArtDataIntoBuffer(palette_t * const pic, uint8_t const * const buf,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// allocatepermanenttile
|
// allocatepermanenttile
|
||||||
//
|
//
|
||||||
intptr_t allocatepermanenttile(int16_t tilenume, int32_t xsiz, int32_t ysiz)
|
intptr_t allocatepermanenttile(int16_t tilenume, int32_t xsiz, int32_t ysiz)
|
||||||
{
|
{
|
||||||
int32_t dasiz;
|
|
||||||
|
|
||||||
if (xsiz <= 0 || ysiz <= 0 || (unsigned) tilenume >= MAXTILES)
|
if (xsiz <= 0 || ysiz <= 0 || (unsigned) tilenume >= MAXTILES)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
dasiz = xsiz*ysiz;
|
int const dasiz = xsiz*ysiz;
|
||||||
|
|
||||||
walock[tilenume] = 255;
|
walock[tilenume] = 255;
|
||||||
allocache(&waloff[tilenume], dasiz, &walock[tilenume]);
|
allocache(&waloff[tilenume], dasiz, &walock[tilenume]);
|
||||||
|
@ -692,6 +679,7 @@ intptr_t allocatepermanenttile(int16_t tilenume, int32_t xsiz, int32_t ysiz)
|
||||||
//
|
//
|
||||||
// copytilepiece
|
// copytilepiece
|
||||||
//
|
//
|
||||||
|
#if 0
|
||||||
void copytilepiece(int32_t tilenume1, int32_t sx1, int32_t sy1, int32_t xsiz, int32_t ysiz,
|
void copytilepiece(int32_t tilenume1, int32_t sx1, int32_t sy1, int32_t xsiz, int32_t ysiz,
|
||||||
int32_t tilenume2, int32_t sx2, int32_t sy2)
|
int32_t tilenume2, int32_t sx2, int32_t sy2)
|
||||||
{
|
{
|
||||||
|
@ -728,6 +716,7 @@ void copytilepiece(int32_t tilenume1, int32_t sx1, int32_t sy1, int32_t xsiz, in
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void Buninitart(void)
|
void Buninitart(void)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue