mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-19 22:00:49 +00:00
- use iterator class for all stat loops in Blood's actor.cpp.
This commit is contained in:
parent
0a0a995cbd
commit
33164694b9
6 changed files with 70 additions and 33 deletions
|
@ -2448,7 +2448,10 @@ void actInit(bool bSaveLoad) {
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
for (int nSprite = headspritestat[kStatItem]; nSprite >= 0; nSprite = nextspritestat[nSprite]) {
|
int nSprite;
|
||||||
|
StatIterator it(kStatItem);
|
||||||
|
while ((nSprite = it.NextIndex()) >= 0)
|
||||||
|
{
|
||||||
switch (sprite[nSprite].type) {
|
switch (sprite[nSprite].type) {
|
||||||
case kItemWeaponVoodooDoll:
|
case kItemWeaponVoodooDoll:
|
||||||
sprite[nSprite].type = kAmmoItemVoodooDoll;
|
sprite[nSprite].type = kAmmoItemVoodooDoll;
|
||||||
|
@ -2456,7 +2459,9 @@ void actInit(bool bSaveLoad) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int nSprite = headspritestat[kStatTraps]; nSprite >= 0; nSprite = nextspritestat[nSprite]) {
|
it.Reset(kStatTraps);
|
||||||
|
while ((nSprite = it.NextIndex()) >= 0)
|
||||||
|
{
|
||||||
spritetype *pSprite = &sprite[nSprite];
|
spritetype *pSprite = &sprite[nSprite];
|
||||||
switch (pSprite->type) {
|
switch (pSprite->type) {
|
||||||
case kTrapExploder:
|
case kTrapExploder:
|
||||||
|
@ -2468,7 +2473,9 @@ void actInit(bool bSaveLoad) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int nSprite = headspritestat[kStatThing]; nSprite >= 0; nSprite = nextspritestat[nSprite]) {
|
it.Reset(kStatThing);
|
||||||
|
while ((nSprite = it.NextIndex()) >= 0)
|
||||||
|
{
|
||||||
if (sprite[nSprite].extra <= 0 || sprite[nSprite].extra >= kMaxXSprites) continue;
|
if (sprite[nSprite].extra <= 0 || sprite[nSprite].extra >= kMaxXSprites) continue;
|
||||||
spritetype* pSprite = &sprite[nSprite]; XSPRITE *pXSprite = &xsprite[pSprite->extra];
|
spritetype* pSprite = &sprite[nSprite]; XSPRITE *pXSprite = &xsprite[pSprite->extra];
|
||||||
|
|
||||||
|
@ -2511,18 +2518,24 @@ void actInit(bool bSaveLoad) {
|
||||||
|
|
||||||
if (gGameOptions.nMonsterSettings == 0) {
|
if (gGameOptions.nMonsterSettings == 0) {
|
||||||
gKillMgr.SetCount(0);
|
gKillMgr.SetCount(0);
|
||||||
while (headspritestat[kStatDude] >= 0) {
|
int nSprite;
|
||||||
spritetype *pSprite = &sprite[headspritestat[kStatDude]];
|
StatIterator it(kStatDude);
|
||||||
|
while ((nSprite = it.NextIndex()) >= 0)
|
||||||
|
{
|
||||||
|
spritetype *pSprite = &sprite[nSprite];
|
||||||
if (pSprite->extra > 0 && pSprite->extra < kMaxXSprites && xsprite[pSprite->extra].key > 0) // Drop Key
|
if (pSprite->extra > 0 && pSprite->extra < kMaxXSprites && xsprite[pSprite->extra].key > 0) // Drop Key
|
||||||
actDropObject(pSprite, kItemKeyBase + (xsprite[pSprite->extra].key - 1));
|
actDropObject(pSprite, kItemKeyBase + (xsprite[pSprite->extra].key - 1));
|
||||||
DeleteSprite(headspritestat[kStatDude]);
|
DeleteSprite(nSprite);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// by NoOne: WTF is this?
|
// by NoOne: WTF is this?
|
||||||
///////////////
|
///////////////
|
||||||
char unk[kDudeMax-kDudeBase];
|
char unk[kDudeMax-kDudeBase];
|
||||||
memset(unk, 0, sizeof(unk));
|
memset(unk, 0, sizeof(unk));
|
||||||
for (int nSprite = headspritestat[kStatDude]; nSprite >= 0; nSprite = nextspritestat[nSprite]) {
|
int nSprite;
|
||||||
|
StatIterator it(kStatDude);
|
||||||
|
while ((nSprite = it.NextIndex()) >= 0)
|
||||||
|
{
|
||||||
spritetype *pSprite = &sprite[nSprite];
|
spritetype *pSprite = &sprite[nSprite];
|
||||||
if (pSprite->type < kDudeBase || pSprite->type >= kDudeMax)
|
if (pSprite->type < kDudeBase || pSprite->type >= kDudeMax)
|
||||||
I_Error("Non-enemy sprite (%d) in the enemy sprite list.\n", nSprite);
|
I_Error("Non-enemy sprite (%d) in the enemy sprite list.\n", nSprite);
|
||||||
|
@ -2536,7 +2549,9 @@ void actInit(bool bSaveLoad) {
|
||||||
for (int j = 0; j < 7; j++)
|
for (int j = 0; j < 7; j++)
|
||||||
dudeInfo[i].at70[j] = mulscale8(DudeDifficulty[gGameOptions.nDifficulty], dudeInfo[i].startDamage[j]);
|
dudeInfo[i].at70[j] = mulscale8(DudeDifficulty[gGameOptions.nDifficulty], dudeInfo[i].startDamage[j]);
|
||||||
|
|
||||||
for (int nSprite = headspritestat[kStatDude]; nSprite >= 0; nSprite = nextspritestat[nSprite]) {
|
it.Reset(kStatDude);
|
||||||
|
while ((nSprite = it.NextIndex()) >= 0)
|
||||||
|
{
|
||||||
if (sprite[nSprite].extra <= 0 || sprite[nSprite].extra >= kMaxXSprites) continue;
|
if (sprite[nSprite].extra <= 0 || sprite[nSprite].extra >= kMaxXSprites) continue;
|
||||||
spritetype *pSprite = &sprite[nSprite]; XSPRITE *pXSprite = &xsprite[pSprite->extra];
|
spritetype *pSprite = &sprite[nSprite]; XSPRITE *pXSprite = &xsprite[pSprite->extra];
|
||||||
|
|
||||||
|
@ -2671,7 +2686,7 @@ void sub_2A620(int nSprite, int x, int y, int z, int nSector, int nDist, int a7,
|
||||||
{
|
{
|
||||||
UNREFERENCED_PARAMETER(a12);
|
UNREFERENCED_PARAMETER(a12);
|
||||||
UNREFERENCED_PARAMETER(a13);
|
UNREFERENCED_PARAMETER(a13);
|
||||||
char va0[(kMaxSectors+7)>>3];
|
uint8_t va0[(kMaxSectors+7)>>3];
|
||||||
int nOwner = actSpriteIdToOwnerId(nSprite);
|
int nOwner = actSpriteIdToOwnerId(nSprite);
|
||||||
gAffectedSectors[0] = 0;
|
gAffectedSectors[0] = 0;
|
||||||
gAffectedXWalls[0] = 0;
|
gAffectedXWalls[0] = 0;
|
||||||
|
@ -2679,7 +2694,9 @@ void sub_2A620(int nSprite, int x, int y, int z, int nSector, int nDist, int a7,
|
||||||
nDist <<= 4;
|
nDist <<= 4;
|
||||||
if (a10 & 2)
|
if (a10 & 2)
|
||||||
{
|
{
|
||||||
for (int i = headspritestat[kStatDude]; i >= 0; i = nextspritestat[i])
|
int i;
|
||||||
|
StatIterator it(kStatDude);
|
||||||
|
while ((i = it.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
if (i != nSprite || (a10 & 1))
|
if (i != nSprite || (a10 & 1))
|
||||||
{
|
{
|
||||||
|
@ -2713,7 +2730,9 @@ void sub_2A620(int nSprite, int x, int y, int z, int nSector, int nDist, int a7,
|
||||||
}
|
}
|
||||||
if (a10 & 4)
|
if (a10 & 4)
|
||||||
{
|
{
|
||||||
for (int i = headspritestat[kStatThing]; i >= 0; i = nextspritestat[i])
|
int i;
|
||||||
|
StatIterator it(kStatThing);
|
||||||
|
while ((i = it.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
spritetype *pSprite2 = &sprite[i];
|
spritetype *pSprite2 = &sprite[i];
|
||||||
|
|
||||||
|
@ -5416,7 +5435,8 @@ void actProcessSprites(void)
|
||||||
if (gModernMap) nnExtProcessSuperSprites();
|
if (gModernMap) nnExtProcessSuperSprites();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
for (nSprite = headspritestat[kStatThing]; nSprite >= 0; nSprite = nextspritestat[nSprite])
|
StatIterator it(kStatThing);
|
||||||
|
while ((nSprite = it.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
spritetype *pSprite = &sprite[nSprite];
|
spritetype *pSprite = &sprite[nSprite];
|
||||||
|
|
||||||
|
@ -5447,9 +5467,10 @@ void actProcessSprites(void)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (pSprite->type == kThingDroppedLifeLeech) pXSprite->target = -1;
|
if (pSprite->type == kThingDroppedLifeLeech) pXSprite->target = -1;
|
||||||
for (int nSprite2 = headspritestat[kStatDude]; nSprite2 >= 0; nSprite2 = nNextSprite)
|
int nSprite2;
|
||||||
|
StatIterator it1(kStatDude);
|
||||||
|
while ((nSprite2 = it1.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
|
|
||||||
nNextSprite = nextspritestat[nSprite2];
|
nNextSprite = nextspritestat[nSprite2];
|
||||||
spritetype *pSprite2 = &sprite[nSprite2];
|
spritetype *pSprite2 = &sprite[nSprite2];
|
||||||
|
|
||||||
|
@ -5511,7 +5532,9 @@ void actProcessSprites(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (nSprite = headspritestat[kStatThing]; nSprite >= 0; nSprite = nextspritestat[nSprite])
|
|
||||||
|
it.Reset(kStatThing);
|
||||||
|
while ((nSprite = it.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
spritetype *pSprite = &sprite[nSprite];
|
spritetype *pSprite = &sprite[nSprite];
|
||||||
|
|
||||||
|
@ -5642,7 +5665,8 @@ void actProcessSprites(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (nSprite = headspritestat[kStatProjectile]; nSprite >= 0; nSprite = nextspritestat[nSprite])
|
it.Reset(kStatProjectile);
|
||||||
|
while ((nSprite = it.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
spritetype *pSprite = &sprite[nSprite];
|
spritetype *pSprite = &sprite[nSprite];
|
||||||
|
|
||||||
|
@ -5653,9 +5677,10 @@ void actProcessSprites(void)
|
||||||
if (hit >= 0)
|
if (hit >= 0)
|
||||||
actImpactMissile(pSprite, hit);
|
actImpactMissile(pSprite, hit);
|
||||||
}
|
}
|
||||||
for (nSprite = headspritestat[kStatExplosion]; nSprite >= 0; nSprite = nextspritestat[nSprite])
|
it.Reset(kStatExplosion);
|
||||||
|
while ((nSprite = it.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
char v24c[(kMaxSectors+7)>>3];
|
uint8_t v24c[(kMaxSectors+7)>>3];
|
||||||
spritetype *pSprite = &sprite[nSprite];
|
spritetype *pSprite = &sprite[nSprite];
|
||||||
|
|
||||||
if (pSprite->flags & 32)
|
if (pSprite->flags & 32)
|
||||||
|
@ -5693,7 +5718,9 @@ void actProcessSprites(void)
|
||||||
trTriggerWall(nWall, pXWall, kCmdWallImpact);
|
trTriggerWall(nWall, pXWall, kCmdWallImpact);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int nSprite2 = headspritestat[kStatDude]; nSprite2 >= 0; nSprite2 = nextspritestat[nSprite2])
|
int nSprite2;
|
||||||
|
StatIterator it1(kStatDude);
|
||||||
|
while ((nSprite2 = it1.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
spritetype *pDude = &sprite[nSprite2];
|
spritetype *pDude = &sprite[nSprite2];
|
||||||
|
|
||||||
|
@ -5722,7 +5749,8 @@ void actProcessSprites(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int nSprite2 = headspritestat[kStatThing]; nSprite2 >= 0; nSprite2 = nextspritestat[nSprite2])
|
it1.Reset(kStatThing);
|
||||||
|
while ((nSprite2 = it1.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
spritetype *pThing = &sprite[nSprite2];
|
spritetype *pThing = &sprite[nSprite2];
|
||||||
|
|
||||||
|
@ -5811,7 +5839,9 @@ void actProcessSprites(void)
|
||||||
actPostSprite(nSprite, kStatFree);
|
actPostSprite(nSprite, kStatFree);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (nSprite = headspritestat[kStatTraps]; nSprite >= 0; nSprite = nextspritestat[nSprite]) {
|
it.Reset(kStatTraps);
|
||||||
|
while ((nSprite = it.NextIndex()) >= 0)
|
||||||
|
{
|
||||||
spritetype *pSprite = &sprite[nSprite];
|
spritetype *pSprite = &sprite[nSprite];
|
||||||
|
|
||||||
if (pSprite->flags & 32)
|
if (pSprite->flags & 32)
|
||||||
|
@ -5853,7 +5883,8 @@ void actProcessSprites(void)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (nSprite = headspritestat[kStatDude]; nSprite >= 0; nSprite = nextspritestat[nSprite])
|
it.Reset(kStatDude);
|
||||||
|
while ((nSprite = it.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
spritetype *pSprite = &sprite[nSprite];
|
spritetype *pSprite = &sprite[nSprite];
|
||||||
|
|
||||||
|
@ -5901,7 +5932,9 @@ void actProcessSprites(void)
|
||||||
}
|
}
|
||||||
if (pXSprite->Proximity && !pXSprite->isTriggered)
|
if (pXSprite->Proximity && !pXSprite->isTriggered)
|
||||||
{
|
{
|
||||||
for (int nSprite2 = headspritestat[kStatDude]; nSprite2 >= 0; nSprite2 = nNextSprite)
|
int nSprite2;
|
||||||
|
StatIterator it1(kStatDude);
|
||||||
|
while ((nSprite2 = it1.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
nNextSprite = nextspritestat[nSprite2];
|
nNextSprite = nextspritestat[nSprite2];
|
||||||
spritetype *pSprite2 = &sprite[nSprite2];
|
spritetype *pSprite2 = &sprite[nSprite2];
|
||||||
|
@ -5955,7 +5988,8 @@ void actProcessSprites(void)
|
||||||
ProcessTouchObjects(pSprite, nXSprite);
|
ProcessTouchObjects(pSprite, nXSprite);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (nSprite = headspritestat[kStatDude]; nSprite >= 0; nSprite = nextspritestat[nSprite])
|
it.Reset(kStatDude);
|
||||||
|
while ((nSprite = it.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
spritetype *pSprite = &sprite[nSprite];
|
spritetype *pSprite = &sprite[nSprite];
|
||||||
|
|
||||||
|
@ -6004,7 +6038,8 @@ void actProcessSprites(void)
|
||||||
velFloor[pSprite->sectnum] || velCeil[pSprite->sectnum])
|
velFloor[pSprite->sectnum] || velCeil[pSprite->sectnum])
|
||||||
MoveDude(pSprite);
|
MoveDude(pSprite);
|
||||||
}
|
}
|
||||||
for (nSprite = headspritestat[kStatFlare]; nSprite >= 0; nSprite = nextspritestat[nSprite])
|
it.Reset(kStatFlare);
|
||||||
|
while ((nSprite = it.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
spritetype *pSprite = &sprite[nSprite];
|
spritetype *pSprite = &sprite[nSprite];
|
||||||
|
|
||||||
|
@ -6051,7 +6086,8 @@ spritetype * actSpawnSprite(int nSector, int x, int y, int z, int nStat, char a6
|
||||||
sprite[nSprite].extra = -1;
|
sprite[nSprite].extra = -1;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
nSprite = headspritestat[kStatPurge];
|
StatIterator it(kStatPurge);
|
||||||
|
nSprite = it.NextIndex();
|
||||||
assert(nSprite >= 0);
|
assert(nSprite >= 0);
|
||||||
assert(nSector >= 0 && nSector < kMaxSectors);
|
assert(nSector >= 0 && nSector < kMaxSectors);
|
||||||
ChangeSpriteSect(nSprite, nSector);
|
ChangeSpriteSect(nSprite, nSector);
|
||||||
|
@ -6142,7 +6178,8 @@ spritetype * actSpawnSprite(spritetype *pSource, int nStat)
|
||||||
int nSprite = InsertSprite(pSource->sectnum, nStat);
|
int nSprite = InsertSprite(pSource->sectnum, nStat);
|
||||||
if (nSprite < 0)
|
if (nSprite < 0)
|
||||||
{
|
{
|
||||||
nSprite = headspritestat[kStatPurge];
|
StatIterator it(kStatPurge);
|
||||||
|
nSprite = it.NextIndex();
|
||||||
assert(nSprite >= 0);
|
assert(nSprite >= 0);
|
||||||
assert(pSource->sectnum >= 0 && pSource->sectnum < kMaxSectors);
|
assert(pSource->sectnum >= 0 && pSource->sectnum < kMaxSectors);
|
||||||
ChangeSpriteSect(nSprite, pSource->sectnum);
|
ChangeSpriteSect(nSprite, pSource->sectnum);
|
||||||
|
|
|
@ -1414,7 +1414,7 @@ void sub_5F15C(spritetype *pSprite, XSPRITE *pXSprite)
|
||||||
}
|
}
|
||||||
if (pXSprite->state)
|
if (pXSprite->state)
|
||||||
{
|
{
|
||||||
char va4[(kMaxSectors+7)>>3];
|
uint8_t va4[(kMaxSectors+7)>>3];
|
||||||
gAffectedSectors[0] = 0;
|
gAffectedSectors[0] = 0;
|
||||||
gAffectedXWalls[0] = 0;
|
gAffectedXWalls[0] = 0;
|
||||||
GetClosestSpriteSectors(pSprite->sectnum, pSprite->x, pSprite->y, 400, gAffectedSectors, va4, gAffectedXWalls);
|
GetClosestSpriteSectors(pSprite->sectnum, pSprite->x, pSprite->y, 400, gAffectedSectors, va4, gAffectedXWalls);
|
||||||
|
|
|
@ -99,7 +99,7 @@ static void SlashSeqCallback(int, int nXSprite)
|
||||||
|
|
||||||
static void StompSeqCallback(int, int nXSprite)
|
static void StompSeqCallback(int, int nXSprite)
|
||||||
{
|
{
|
||||||
char vb8[(kMaxSectors+7)>>3];
|
uint8_t vb8[(kMaxSectors+7)>>3];
|
||||||
XSPRITE *pXSprite = &xsprite[nXSprite];
|
XSPRITE *pXSprite = &xsprite[nXSprite];
|
||||||
int nSprite = pXSprite->reference;
|
int nSprite = pXSprite->reference;
|
||||||
spritetype *pSprite = &sprite[nSprite];
|
spritetype *pSprite = &sprite[nSprite];
|
||||||
|
|
|
@ -832,9 +832,9 @@ int GetClosestSectors(int nSector, int x, int y, int nDist, short *pSectors, cha
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
|
|
||||||
int GetClosestSpriteSectors(int nSector, int x, int y, int nDist, short *pSectors, char *pSectBit, short *a8)
|
int GetClosestSpriteSectors(int nSector, int x, int y, int nDist, short *pSectors, uint8_t *pSectBit, short *a8)
|
||||||
{
|
{
|
||||||
char sectbits[(kMaxSectors+7)>>3];
|
uint8_t sectbits[(kMaxSectors+7)>>3];
|
||||||
assert(pSectors != NULL);
|
assert(pSectors != NULL);
|
||||||
memset(sectbits, 0, sizeof(sectbits));
|
memset(sectbits, 0, sizeof(sectbits));
|
||||||
pSectors[0] = nSector;
|
pSectors[0] = nSector;
|
||||||
|
|
|
@ -81,7 +81,7 @@ void GetZRangeAtXYZ(int x, int y, int z, int nSector, int *ceilZ, int *ceilHit,
|
||||||
int GetDistToLine(int x1, int y1, int x2, int y2, int x3, int y3);
|
int GetDistToLine(int x1, int y1, int x2, int y2, int x3, int y3);
|
||||||
unsigned int ClipMove(int *x, int *y, int *z, int *nSector, int xv, int yv, int wd, int cd, int fd, unsigned int nMask);
|
unsigned int ClipMove(int *x, int *y, int *z, int *nSector, int xv, int yv, int wd, int cd, int fd, unsigned int nMask);
|
||||||
int GetClosestSectors(int nSector, int x, int y, int nDist, short *pSectors, char *pSectBit);
|
int GetClosestSectors(int nSector, int x, int y, int nDist, short *pSectors, char *pSectBit);
|
||||||
int GetClosestSpriteSectors(int nSector, int x, int y, int nDist, short *pSectors, char *pSectBit, short *a8);
|
int GetClosestSpriteSectors(int nSector, int x, int y, int nDist, short *pSectors, uint8_t *pSectBit, short *a8);
|
||||||
int picWidth(short nPic, short repeat);
|
int picWidth(short nPic, short repeat);
|
||||||
int picHeight(short nPic, short repeat);
|
int picHeight(short nPic, short repeat);
|
||||||
|
|
||||||
|
|
|
@ -2493,7 +2493,7 @@ void WeaponProcess(PLAYER *pPlayer) {
|
||||||
|
|
||||||
void sub_51340(spritetype *pMissile, int a2)
|
void sub_51340(spritetype *pMissile, int a2)
|
||||||
{
|
{
|
||||||
char va4[(kMaxSectors+7)>>3];
|
uint8_t va4[(kMaxSectors+7)>>3];
|
||||||
int x = pMissile->x;
|
int x = pMissile->x;
|
||||||
int y = pMissile->y;
|
int y = pMissile->y;
|
||||||
int z = pMissile->z;
|
int z = pMissile->z;
|
||||||
|
|
Loading…
Reference in a new issue