mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
Clean up updatesector* family, no functional changes.
- factor out the "is inside" predicates - rename updatesector_onlynextwalls() -> updatesectorbreadth() - add ATTRIBUTE((nonnull(4))) to the bitmap arg of updatesectorexclude(). git-svn-id: https://svn.eduke32.com/eduke32@3037 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
6019e86010
commit
d4ff4c4595
4 changed files with 85 additions and 75 deletions
|
@ -671,9 +671,9 @@ void neartag(int32_t xs, int32_t ys, int32_t zs, int16_t sectnum, int16_t ange
|
||||||
int32_t cansee(int32_t x1, int32_t y1, int32_t z1, int16_t sect1,
|
int32_t cansee(int32_t x1, int32_t y1, int32_t z1, int16_t sect1,
|
||||||
int32_t x2, int32_t y2, int32_t z2, int16_t sect2);
|
int32_t x2, int32_t y2, int32_t z2, int16_t sect2);
|
||||||
void updatesector(int32_t x, int32_t y, int16_t *sectnum) ATTRIBUTE((nonnull(3)));
|
void updatesector(int32_t x, int32_t y, int16_t *sectnum) ATTRIBUTE((nonnull(3)));
|
||||||
void updatesector_onlynextwalls(int32_t x, int32_t y, int16_t *sectnum) ATTRIBUTE((nonnull(3)));
|
void updatesectorbreadth(int32_t x, int32_t y, int16_t *sectnum) ATTRIBUTE((nonnull(3)));
|
||||||
void updatesectorexclude(int32_t x, int32_t y, int16_t *sectnum,
|
void updatesectorexclude(int32_t x, int32_t y, int16_t *sectnum,
|
||||||
const uint8_t *excludesectbitmap) ATTRIBUTE((nonnull(3)));
|
const uint8_t *excludesectbitmap) ATTRIBUTE((nonnull(3,4)));
|
||||||
void updatesectorz(int32_t x, int32_t y, int32_t z, int16_t *sectnum) ATTRIBUTE((nonnull(4)));
|
void updatesectorz(int32_t x, int32_t y, int32_t z, int16_t *sectnum) ATTRIBUTE((nonnull(4)));
|
||||||
int32_t inside(int32_t x, int32_t y, int16_t sectnum);
|
int32_t inside(int32_t x, int32_t y, int16_t sectnum);
|
||||||
void dragpoint(int16_t pointhighlight, int32_t dax, int32_t day);
|
void dragpoint(int16_t pointhighlight, int32_t dax, int32_t day);
|
||||||
|
|
|
@ -5211,7 +5211,7 @@ end_after_dragging:
|
||||||
vec.z = sprite[daspr].z;
|
vec.z = sprite[daspr].z;
|
||||||
if (setspritez(daspr, &vec) == -1 && osec>=0)
|
if (setspritez(daspr, &vec) == -1 && osec>=0)
|
||||||
{
|
{
|
||||||
updatesector_onlynextwalls(dax, day, &nsec);
|
updatesectorbreadth(dax, day, &nsec);
|
||||||
|
|
||||||
if (nsec >= 0)
|
if (nsec >= 0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -12843,47 +12843,70 @@ void bfirst_search_try(int16_t *list, uint8_t *bitmap, int32_t *eltnumptr, int16
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
////////// UPDATESECTOR* FAMILY OF FUNCTIONS //////////
|
||||||
|
|
||||||
|
/* Different "is inside" predicates.
|
||||||
|
* NOTE: The redundant bound checks are expected to be optimized away in the
|
||||||
|
* inlined code. */
|
||||||
|
static inline int32_t inside_p(int32_t x, int32_t y, int16_t sectnum)
|
||||||
|
{
|
||||||
|
return (sectnum>=0 && inside(x, y, sectnum) == 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline int32_t inside_exclude_p(int32_t x, int32_t y, int16_t i, const uint8_t *excludesectbitmap)
|
||||||
|
{
|
||||||
|
return (i>=0 && !(excludesectbitmap[i>>3]&(1<<(i&7))) && inside_p(x, y, i));
|
||||||
|
}
|
||||||
|
|
||||||
|
/* NOTE: no bound check */
|
||||||
|
static inline int32_t inside_z_p(int32_t x, int32_t y, int32_t z, int16_t i)
|
||||||
|
{
|
||||||
|
int32_t cz, fz;
|
||||||
|
getzsofslope(i, x, y, &cz, &fz);
|
||||||
|
return (z >= cz && z <= fz && inside_p(x, y, i));
|
||||||
|
}
|
||||||
|
|
||||||
|
#define SET_AND_RETURN(Lval, Rval) do \
|
||||||
|
{ \
|
||||||
|
(Lval) = (Rval); \
|
||||||
|
return; \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// updatesector[z]
|
// updatesector[z]
|
||||||
//
|
//
|
||||||
void updatesector(int32_t x, int32_t y, int16_t *sectnum)
|
void updatesector(int32_t x, int32_t y, int16_t *sectnum)
|
||||||
{
|
{
|
||||||
walltype *wal;
|
int32_t i;
|
||||||
int32_t i, j;
|
|
||||||
|
|
||||||
if (inside(x,y,*sectnum) == 1) return;
|
if (inside_p(x,y,*sectnum))
|
||||||
|
return;
|
||||||
|
|
||||||
if ((*sectnum >= 0) && (*sectnum < numsectors))
|
if (*sectnum >= 0 && *sectnum < numsectors)
|
||||||
{
|
{
|
||||||
wal = &wall[sector[*sectnum].wallptr];
|
const walltype *wal = &wall[sector[*sectnum].wallptr];
|
||||||
j = sector[*sectnum].wallnum;
|
int32_t j = sector[*sectnum].wallnum;
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
i = wal->nextsector;
|
i = wal->nextsector;
|
||||||
if (i >= 0)
|
if (inside_p(x, y, i))
|
||||||
if (inside(x,y,(int16_t)i) == 1)
|
SET_AND_RETURN(*sectnum, i);
|
||||||
{
|
|
||||||
*sectnum = i;
|
wal++; j--;
|
||||||
return;
|
|
||||||
}
|
|
||||||
wal++;
|
|
||||||
j--;
|
|
||||||
}
|
}
|
||||||
while (j != 0);
|
while (j != 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i=numsectors-1; i>=0; i--)
|
for (i=numsectors-1; i>=0; i--)
|
||||||
if (inside(x,y,(int16_t)i) == 1)
|
if (inside_p(x, y, i))
|
||||||
{
|
SET_AND_RETURN(*sectnum, i);
|
||||||
*sectnum = i;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
*sectnum = -1;
|
*sectnum = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void updatesector_onlynextwalls(int32_t x, int32_t y, int16_t *sectnum)
|
void updatesectorbreadth(int32_t x, int32_t y, int16_t *sectnum)
|
||||||
{
|
{
|
||||||
static int16_t sectlist[MAXSECTORS];
|
static int16_t sectlist[MAXSECTORS];
|
||||||
static uint8_t sectbitmap[MAXSECTORS>>3];
|
static uint8_t sectbitmap[MAXSECTORS>>3];
|
||||||
|
@ -12895,19 +12918,16 @@ void updatesector_onlynextwalls(int32_t x, int32_t y, int16_t *sectnum)
|
||||||
bfirst_search_init(sectlist, sectbitmap, &nsecs, numsectors, *sectnum);
|
bfirst_search_init(sectlist, sectbitmap, &nsecs, numsectors, *sectnum);
|
||||||
|
|
||||||
for (sectcnt=0; sectcnt<nsecs; sectcnt++)
|
for (sectcnt=0; sectcnt<nsecs; sectcnt++)
|
||||||
|
{
|
||||||
|
if (inside_p(x,y, sectlist[sectcnt]))
|
||||||
|
SET_AND_RETURN(*sectnum, sectlist[sectcnt]);
|
||||||
|
|
||||||
{
|
{
|
||||||
const sectortype *sec = §or[sectlist[sectcnt]];
|
const sectortype *sec = §or[sectlist[sectcnt]];
|
||||||
int32_t startwall = sec->wallptr;
|
int32_t startwall = sec->wallptr;
|
||||||
int32_t endwall = sec->wallptr + sec->wallnum;
|
int32_t endwall = sec->wallptr + sec->wallnum;
|
||||||
|
|
||||||
if (inside(x,y, sectlist[sectcnt]) == 1)
|
|
||||||
{
|
|
||||||
*sectnum = sectlist[sectcnt];
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (j=startwall; j<endwall; j++)
|
for (j=startwall; j<endwall; j++)
|
||||||
{
|
|
||||||
if (wall[j].nextsector >= 0)
|
if (wall[j].nextsector >= 0)
|
||||||
bfirst_search_try(sectlist, sectbitmap, &nsecs, wall[j].nextsector);
|
bfirst_search_try(sectlist, sectbitmap, &nsecs, wall[j].nextsector);
|
||||||
}
|
}
|
||||||
|
@ -12918,37 +12938,30 @@ void updatesector_onlynextwalls(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)
|
||||||
{
|
{
|
||||||
walltype *wal;
|
int32_t i;
|
||||||
int32_t i, j;
|
|
||||||
|
|
||||||
if (*sectnum>=0 && !(excludesectbitmap[*sectnum>>3]&(1<<(*sectnum&7))) && inside(x,y,*sectnum) == 1)
|
if (inside_exclude_p(x, y, *sectnum, excludesectbitmap))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if ((*sectnum >= 0) && (*sectnum < numsectors))
|
if (*sectnum >= 0 && *sectnum < numsectors)
|
||||||
{
|
{
|
||||||
wal = &wall[sector[*sectnum].wallptr];
|
const walltype *wal = &wall[sector[*sectnum].wallptr];
|
||||||
j = sector[*sectnum].wallnum;
|
int32_t j = sector[*sectnum].wallnum;
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
i = wal->nextsector;
|
i = wal->nextsector;
|
||||||
if (i >= 0)
|
if (inside_exclude_p(x, y, i, excludesectbitmap))
|
||||||
if (!(excludesectbitmap[i>>3]&(1<<(i&7))) && inside(x,y,(int16_t)i) == 1)
|
SET_AND_RETURN(*sectnum, i);
|
||||||
{
|
|
||||||
*sectnum = i;
|
wal++; j--;
|
||||||
return;
|
|
||||||
}
|
|
||||||
wal++;
|
|
||||||
j--;
|
|
||||||
}
|
}
|
||||||
while (j != 0);
|
while (j != 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i=numsectors-1; i>=0; i--)
|
for (i=numsectors-1; i>=0; i--)
|
||||||
if (!(excludesectbitmap[i>>3]&(1<<(i&7))) && inside(x,y,(int16_t)i) == 1)
|
if (inside_exclude_p(x, y, i, excludesectbitmap))
|
||||||
{
|
SET_AND_RETURN(*sectnum, i);
|
||||||
*sectnum = i;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
*sectnum = -1;
|
*sectnum = -1;
|
||||||
}
|
}
|
||||||
|
@ -12958,11 +12971,13 @@ 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)
|
||||||
{
|
{
|
||||||
walltype *wal;
|
int32_t i;
|
||||||
int32_t i, j, cz, fz;
|
|
||||||
|
|
||||||
if ((uint32_t)(*sectnum) < 2*MAXSECTORS)
|
if ((uint32_t)(*sectnum) < 2*MAXSECTORS)
|
||||||
{
|
{
|
||||||
|
const walltype *wal;
|
||||||
|
int32_t j, cz, fz;
|
||||||
|
|
||||||
int32_t nofirstzcheck = 0;
|
int32_t nofirstzcheck = 0;
|
||||||
|
|
||||||
if (*sectnum >= MAXSECTORS)
|
if (*sectnum >= MAXSECTORS)
|
||||||
|
@ -12979,43 +12994,37 @@ void updatesectorz(int32_t x, int32_t y, int32_t z, int16_t *sectnum)
|
||||||
{
|
{
|
||||||
i = yax_getneighborsect(x, y, *sectnum, YAX_CEILING, NULL);
|
i = yax_getneighborsect(x, y, *sectnum, YAX_CEILING, NULL);
|
||||||
if (i >= 0 && z >= getceilzofslope(i, x, y))
|
if (i >= 0 && z >= getceilzofslope(i, x, y))
|
||||||
{ *sectnum = i; return; }
|
SET_AND_RETURN(*sectnum, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (z > fz)
|
if (z > fz)
|
||||||
{
|
{
|
||||||
i = yax_getneighborsect(x, y, *sectnum, YAX_FLOOR, NULL);
|
i = yax_getneighborsect(x, y, *sectnum, YAX_FLOOR, NULL);
|
||||||
if (i >= 0 && z <= getflorzofslope(i, x, y))
|
if (i >= 0 && z <= getflorzofslope(i, x, y))
|
||||||
{ *sectnum = i; return; }
|
SET_AND_RETURN(*sectnum, i);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (nofirstzcheck || ((z >= cz) && (z <= fz)))
|
if (nofirstzcheck || (z >= cz && z <= fz))
|
||||||
if (inside(x,y,*sectnum) != 0) return;
|
if (inside_p(x, y, *sectnum))
|
||||||
|
return;
|
||||||
|
|
||||||
wal = &wall[sector[*sectnum].wallptr];
|
wal = &wall[sector[*sectnum].wallptr];
|
||||||
j = sector[*sectnum].wallnum;
|
j = sector[*sectnum].wallnum;
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
|
// YAX: TODO: check neighboring sectors here too?
|
||||||
i = wal->nextsector;
|
i = wal->nextsector;
|
||||||
if (i >= 0)
|
if (i>=0 && inside_z_p(x,y,z, i))
|
||||||
{
|
SET_AND_RETURN(*sectnum, i);
|
||||||
// YAX: TODO: check neighboring sectors here too?
|
|
||||||
getzsofslope(i, x, y, &cz, &fz);
|
|
||||||
if ((z >= cz) && (z <= fz))
|
|
||||||
if (inside(x,y,(int16_t)i) == 1)
|
|
||||||
{ *sectnum = i; return; }
|
|
||||||
}
|
|
||||||
wal++; j--;
|
wal++; j--;
|
||||||
}
|
}
|
||||||
while (j != 0);
|
while (j != 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i=numsectors-1; i>=0; i--)
|
for (i=numsectors-1; i>=0; i--)
|
||||||
{
|
if (inside_z_p(x,y,z, i))
|
||||||
getzsofslope(i, x, y, &cz, &fz);
|
SET_AND_RETURN(*sectnum, i);
|
||||||
if ((z >= cz) && (z <= fz))
|
|
||||||
if (inside(x,y,(int16_t)i) == 1)
|
|
||||||
{ *sectnum = i; return; }
|
|
||||||
}
|
|
||||||
|
|
||||||
*sectnum = -1;
|
*sectnum = -1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -995,8 +995,9 @@ void polymer_drawrooms(int32_t daposx, int32_t daposy, int32_t da
|
||||||
bglGetFloatv(GL_MODELVIEW_MATRIX, rootmodelviewmatrix);
|
bglGetFloatv(GL_MODELVIEW_MATRIX, rootmodelviewmatrix);
|
||||||
|
|
||||||
cursectnum = dacursectnum;
|
cursectnum = dacursectnum;
|
||||||
updatesector_onlynextwalls(daposx, daposy, &cursectnum);
|
updatesectorbreadth(daposx, daposy, &cursectnum);
|
||||||
if ((cursectnum >= 0) && (cursectnum < numsectors))
|
|
||||||
|
if (cursectnum >= 0 && cursectnum < numsectors)
|
||||||
dacursectnum = cursectnum;
|
dacursectnum = cursectnum;
|
||||||
else if (pr_verbosity>=2)
|
else if (pr_verbosity>=2)
|
||||||
OSD_Printf("PR : got sector %d after update!\n", cursectnum);
|
OSD_Printf("PR : got sector %d after update!\n", cursectnum);
|
||||||
|
|
Loading…
Reference in a new issue