Remix sprite list manipulation functions.

Factor out two helper functions, do_deletesprite{sect,stat}
and do_insertsprite_at_headof{sect,stat}.

git-svn-id: https://svn.eduke32.com/eduke32@2466 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
helixhorned 2012-03-13 20:06:07 +00:00
parent 846214a164
commit 60d70854c8

View file

@ -7503,9 +7503,25 @@ int32_t getclosestcol(int32_t r, int32_t g, int32_t b)
} }
// ////////// SPRITE LIST MANIPULATION FUNCTIONS //////////
///// sprite lists /////
// insert sprite at the head of sector list, change .sectnum
static void do_insertsprite_at_headofsect(int16_t spritenum, int16_t sectnum)
{
int16_t ohead = headspritesect[sectnum];
prevspritesect[spritenum] = -1;
nextspritesect[spritenum] = ohead;
if (ohead >= 0)
prevspritesect[ohead] = spritenum;
headspritesect[sectnum] = spritenum;
sprite[spritenum].sectnum = sectnum;
}
// insertspritesect (internal) // insertspritesect (internal)
//
static int32_t insertspritesect(int16_t sectnum) static int32_t insertspritesect(int16_t sectnum)
{ {
int16_t blanktouse; int16_t blanktouse;
@ -7517,29 +7533,63 @@ static int32_t insertspritesect(int16_t sectnum)
blanktouse = headspritesect[MAXSECTORS]; blanktouse = headspritesect[MAXSECTORS];
headspritesect[MAXSECTORS] = nextspritesect[blanktouse]; headspritesect[MAXSECTORS] = nextspritesect[blanktouse];
// make 'previous' link of the new freelist head point to nil // make back-link of the new freelist head point to nil
if (headspritesect[MAXSECTORS] >= 0) if (headspritesect[MAXSECTORS] >= 0)
prevspritesect[headspritesect[MAXSECTORS]] = -1; prevspritesect[headspritesect[MAXSECTORS]] = -1;
// insert the fetched sprite at the head of the sectnum list do_insertsprite_at_headofsect(blanktouse, sectnum);
prevspritesect[blanktouse] = -1;
nextspritesect[blanktouse] = headspritesect[sectnum];
if (headspritesect[sectnum] >= 0)
prevspritesect[headspritesect[sectnum]] = blanktouse;
headspritesect[sectnum] = blanktouse;
sprite[blanktouse].sectnum = sectnum;
return(blanktouse); return(blanktouse);
} }
// remove sprite 'deleteme' from its sector list
static void do_deletespritesect(int16_t deleteme)
{
int32_t sectnum = sprite[deleteme].sectnum;
int32_t prev = prevspritesect[deleteme], next = nextspritesect[deleteme];
if (headspritesect[sectnum] == deleteme)
headspritesect[sectnum] = next;
if (prev >= 0)
nextspritesect[prev] = next;
if (next >= 0)
prevspritesect[next] = prev;
}
// deletespritesect (internal)
static int32_t deletespritesect(int16_t deleteme)
{
// only non-redundant from deletesprite():
if (sprite[deleteme].sectnum == MAXSECTORS)
return(-1); // already not in the world
do_deletespritesect(deleteme);
// put the deleted sprite at the head of the sectnum-freelist:
do_insertsprite_at_headofsect(deleteme, MAXSECTORS);
return(0);
}
///// the same thing, now for status lists /////
// insert sprite at the head of status list, change .statnum
static void do_insertsprite_at_headofstat(int16_t spritenum, int16_t statnum)
{
int16_t ohead = headspritestat[statnum];
prevspritestat[spritenum] = -1;
nextspritestat[spritenum] = ohead;
if (ohead >= 0)
prevspritestat[ohead] = spritenum;
headspritestat[statnum] = spritenum;
sprite[spritenum].statnum = statnum;
}
//
// insertspritestat (internal) // insertspritestat (internal)
//
static int32_t insertspritestat(int16_t statnum) static int32_t insertspritestat(int16_t statnum)
{ {
int16_t blanktouse; // a spritenum with no assigned statnum int16_t blanktouse;
if ((statnum >= MAXSTATUS) || (headspritestat[MAXSTATUS] == -1)) if ((statnum >= MAXSTATUS) || (headspritestat[MAXSTATUS] == -1))
return(-1); //list full return(-1); //list full
@ -7548,72 +7598,39 @@ static int32_t insertspritestat(int16_t statnum)
blanktouse = headspritestat[MAXSTATUS]; blanktouse = headspritestat[MAXSTATUS];
headspritestat[MAXSTATUS] = nextspritestat[blanktouse]; headspritestat[MAXSTATUS] = nextspritestat[blanktouse];
// make 'previous' link of the new freelist head point to nil // make back-link of the new freelist head point to nil
if (headspritestat[MAXSTATUS] >= 0) if (headspritestat[MAXSTATUS] >= 0)
prevspritestat[headspritestat[MAXSTATUS]] = -1; prevspritestat[headspritestat[MAXSTATUS]] = -1;
// insert the fetched sprite at the head of the statnum list do_insertsprite_at_headofstat(blanktouse, statnum);
prevspritestat[blanktouse] = -1;
nextspritestat[blanktouse] = headspritestat[statnum];
if (headspritestat[statnum] >= 0)
prevspritestat[headspritestat[statnum]] = blanktouse;
headspritestat[statnum] = blanktouse;
sprite[blanktouse].statnum = statnum;
return(blanktouse); return(blanktouse);
} }
// remove sprite 'deleteme' from its status list
// static void do_deletespritestat(int16_t deleteme)
// deletespritesect (internal)
//
static int32_t deletespritesect(int16_t deleteme)
{ {
// only non-redundant from deletesprite(): int32_t sectnum = sprite[deleteme].statnum;
if (sprite[deleteme].sectnum == MAXSECTORS) int32_t prev = prevspritestat[deleteme], next = nextspritestat[deleteme];
return(-1); // already not in the world
if (headspritesect[sprite[deleteme].sectnum] == deleteme) if (headspritestat[sectnum] == deleteme)
headspritesect[sprite[deleteme].sectnum] = nextspritesect[deleteme]; headspritestat[sectnum] = next;
if (prev >= 0)
if (prevspritesect[deleteme] >= 0) nextspritesect[prevspritesect[deleteme]] = nextspritesect[deleteme]; nextspritestat[prev] = next;
if (nextspritesect[deleteme] >= 0) prevspritesect[nextspritesect[deleteme]] = prevspritesect[deleteme]; if (next >= 0)
prevspritestat[next] = prev;
// put the deleted sprite at the head of the sectnum-freelist
if (headspritesect[MAXSECTORS] >= 0) prevspritesect[headspritesect[MAXSECTORS]] = deleteme;
prevspritesect[deleteme] = -1;
nextspritesect[deleteme] = headspritesect[MAXSECTORS];
headspritesect[MAXSECTORS] = deleteme;
sprite[deleteme].sectnum = MAXSECTORS;
return(0);
} }
//
// deletespritestat (internal) // deletespritestat (internal)
//
static int32_t deletespritestat(int16_t deleteme) static int32_t deletespritestat(int16_t deleteme)
{ {
// only non-redundant from deletesprite(): // only non-redundant from deletesprite():
if (sprite[deleteme].statnum == MAXSTATUS) if (sprite[deleteme].statnum == MAXSTATUS)
return(-1); // already not in the world return(-1); // already not in the world
if (headspritestat[sprite[deleteme].statnum] == deleteme) do_deletespritestat(deleteme);
headspritestat[sprite[deleteme].statnum] = nextspritestat[deleteme];
if (prevspritestat[deleteme] >= 0) nextspritestat[prevspritestat[deleteme]] = nextspritestat[deleteme];
if (nextspritestat[deleteme] >= 0) prevspritestat[nextspritestat[deleteme]] = prevspritestat[deleteme];
// put the deleted sprite at the head of the statnum-freelist // put the deleted sprite at the head of the statnum-freelist
if (headspritestat[MAXSTATUS] >= 0) prevspritestat[headspritestat[MAXSTATUS]] = deleteme; do_insertsprite_at_headofstat(deleteme, MAXSTATUS);
prevspritestat[deleteme] = -1;
nextspritestat[deleteme] = headspritestat[MAXSTATUS];
headspritestat[MAXSTATUS] = deleteme;
sprite[deleteme].statnum = MAXSTATUS;
return(0); return(0);
} }