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:
helixhorned 2012-10-01 17:52:09 +00:00
parent 6019e86010
commit d4ff4c4595
4 changed files with 85 additions and 75 deletions

View file

@ -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);

View file

@ -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)
{ {

View file

@ -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 = &sector[sectlist[sectcnt]]; const sectortype *sec = &sector[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
{ {
i = wal->nextsector;
if (i >= 0)
{
// YAX: TODO: check neighboring sectors here too? // YAX: TODO: check neighboring sectors here too?
getzsofslope(i, x, y, &cz, &fz); i = wal->nextsector;
if ((z >= cz) && (z <= fz)) if (i>=0 && inside_z_p(x,y,z, i))
if (inside(x,y,(int16_t)i) == 1) SET_AND_RETURN(*sectnum, i);
{ *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;
} }

View file

@ -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);