mirror of
https://github.com/DrBeef/Raze.git
synced 2025-01-18 15:11:51 +00:00
Lunatic: actions prototype, not enabled even in the dev build.
For Lunatic, we'll want to get rid of the t_data --> script indirections, since the latter will be no more. Thus, all parameters are saved in t_data directly. For the normal build, there are no changes, only stylistic tweaks. git-svn-id: https://svn.eduke32.com/eduke32@2669 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
165c569cbe
commit
f5fb70250a
4 changed files with 62 additions and 16 deletions
|
@ -699,7 +699,13 @@ static void A_MoveSector(int32_t i)
|
|||
}
|
||||
}
|
||||
|
||||
#define LIGHTRAD_PICOFS (T5 ? *(script+T5) + (*(script+T5+2))*T4 : 0)
|
||||
#if 1 //ndef LUNATIC
|
||||
# define LIGHTRAD_PICOFS (T5 ? *(script+T5) + (*(script+T5+2))*T4 : 0)
|
||||
#else
|
||||
// SACTION
|
||||
// startframe + viewtype*???
|
||||
# define LIGHTRAD_PICOFS (SACTION_STARTFRAME(actor[i].t_data) + SACTION_VIEWTYPE(actor[i].t_data)*T4)
|
||||
#endif
|
||||
|
||||
// this is the same crap as in game.c's tspr manipulation. puke.
|
||||
#define LIGHTRAD (s->yrepeat * tilesizy[s->picnum+LIGHTRAD_PICOFS])
|
||||
|
|
|
@ -43,6 +43,15 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|||
#define STAT_DUMMYPLAYER 13
|
||||
#define STAT_LIGHT 14
|
||||
|
||||
#ifdef LUNATIC
|
||||
// Ai, action, move getters from t_data[] (== tptr)
|
||||
# define SACTION_STARTFRAME(tptr) ((tptr)[6]&65535)
|
||||
# define SACTION_NUMFRAMES(tptr) (((tptr)[6]>>16)&65535)
|
||||
# define SACTION_VIEWTYPE(tptr) ((tptr)[7]&0x7fffffff)
|
||||
# define SACTION_INCVAL(tptr) ((tptr)[7]>>31) // arithmetic shr expected!
|
||||
# define SACTION_DELAY(tptr) ((tptr)[8]&65535)
|
||||
#endif
|
||||
|
||||
// Defines the motion characteristics of an actor
|
||||
enum amoveflags_t {
|
||||
face_player = 1,
|
||||
|
|
|
@ -5995,7 +5995,7 @@ static int32_t maybe_take_on_pal_of_floor(spritetype *datspr, int32_t sect)
|
|||
void G_DoSpriteAnimations(int32_t x,int32_t y,int32_t a,int32_t smoothratio)
|
||||
{
|
||||
int32_t i, j, k, p, sect;
|
||||
intptr_t l, t1,t3,t4;
|
||||
intptr_t l, t_data1,t_data3,t_data4;
|
||||
spritetype *s,*t;
|
||||
int32_t switchpic;
|
||||
|
||||
|
@ -6130,6 +6130,9 @@ void G_DoSpriteAnimations(int32_t x,int32_t y,int32_t a,int32_t smoothratio)
|
|||
|
||||
for (j=spritesortcnt-1; j>=0; j--) //Between drawrooms() and drawmasks()
|
||||
{
|
||||
#if 0 // def LUNATIC
|
||||
const int32_t *tptr;
|
||||
#endif
|
||||
//is the perfect time to animate sprites
|
||||
t = &tsprite[j];
|
||||
i = t->owner;
|
||||
|
@ -6227,9 +6230,14 @@ void G_DoSpriteAnimations(int32_t x,int32_t y,int32_t a,int32_t smoothratio)
|
|||
}
|
||||
|
||||
sect = s->sectnum;
|
||||
t1 = T2;
|
||||
t3 = T4;
|
||||
t4 = T5;
|
||||
t_data1 = T2;
|
||||
t_data3 = T4;
|
||||
#if 1 // ndef LUNATIC
|
||||
t_data4 = T5; // SACTION
|
||||
#else
|
||||
tptr = &actor[i].t_data;
|
||||
#endif
|
||||
|
||||
switchpic = s->picnum;
|
||||
//some special cases because dynamictostatic system can't handle addition to constants
|
||||
if ((s->picnum >= SCRAP6)&&(s->picnum<=SCRAP6+7))
|
||||
|
@ -6365,7 +6373,7 @@ void G_DoSpriteAnimations(int32_t x,int32_t y,int32_t a,int32_t smoothratio)
|
|||
}
|
||||
else t->cstat &= ~4;
|
||||
|
||||
if (klabs(t3) > 64) k += 7;
|
||||
if (klabs(t_data3) > 64) k += 7;
|
||||
t->picnum = RECON+k;
|
||||
|
||||
break;
|
||||
|
@ -6497,9 +6505,14 @@ void G_DoSpriteAnimations(int32_t x,int32_t y,int32_t a,int32_t smoothratio)
|
|||
|
||||
if (g_player[p].ps->newowner > -1)
|
||||
{
|
||||
t4 = *(actorscrptr[APLAYER]+1);
|
||||
t3 = 0;
|
||||
t1 = *(actorscrptr[APLAYER]+2);
|
||||
#if 1 // ndef LUNATIC
|
||||
t_data4 = *(actorscrptr[APLAYER]+1);
|
||||
#else
|
||||
// Lunatic TODO: SACTION of APLAYER
|
||||
tptr = (void)0; // forced compilation error
|
||||
#endif
|
||||
t_data3 = 0;
|
||||
t_data1 = *(actorscrptr[APLAYER]+2);
|
||||
}
|
||||
|
||||
if (ud.camerasprite == -1 && g_player[p].ps->newowner == -1)
|
||||
|
@ -6606,10 +6619,14 @@ PALONLY:
|
|||
}
|
||||
*/
|
||||
|
||||
if ((unsigned)t4 + 2 >= (unsigned)g_scriptSize)
|
||||
#if 1 //ndef LUNATIC
|
||||
if ((unsigned)t_data4 + 2 >= (unsigned)g_scriptSize)
|
||||
goto skip;
|
||||
|
||||
l = *(script + t4 + 2);
|
||||
l = *(script + t_data4 + 2);
|
||||
#else
|
||||
l = SACTION_VIEWTYPE(tptr);
|
||||
#endif
|
||||
|
||||
#ifdef USE_OPENGL
|
||||
if (getrendermode() >= 3 && usemodels && md_tilehasmodel(s->picnum,t->pal) >= 0 && !(spriteext[i].flags&SPREXT_NOTMD))
|
||||
|
@ -6665,7 +6682,11 @@ PALONLY:
|
|||
break;
|
||||
}
|
||||
|
||||
t->picnum += k + *(script + t4) + l*t3;
|
||||
#if 1 // ndef LUNATIC
|
||||
t->picnum += k + *(script + t_data4) + l*t_data3;
|
||||
#else
|
||||
t->picnum += k + SACTION_STARTFRAME(tptr) + l*t_data3;
|
||||
#endif
|
||||
|
||||
if (l > 0)
|
||||
while (tilesizx[t->picnum] == 0 && t->picnum > 0)
|
||||
|
@ -6824,7 +6845,7 @@ skip:
|
|||
break;
|
||||
|
||||
case WATERSPLASH2__STATIC:
|
||||
t->picnum = WATERSPLASH2+t1;
|
||||
t->picnum = WATERSPLASH2+t_data1;
|
||||
break;
|
||||
case SHELL__STATIC:
|
||||
t->picnum = s->picnum+(T1&1);
|
||||
|
|
|
@ -5004,17 +5004,27 @@ void A_Execute(int32_t iActor,int32_t iPlayer,int32_t lDist)
|
|||
/* Helixhorned: let's do away with intptr_t's... */
|
||||
if ((unsigned)vm.g_t[4] + 4 < (unsigned)g_scriptSize)
|
||||
{
|
||||
#if 1 //ndef LUNATIC
|
||||
const int32_t action_frames = *(script + vm.g_t[4] + 1);
|
||||
const int32_t action_incval = *(script + vm.g_t[4] + 3);
|
||||
const int32_t action_delay = *(script + vm.g_t[4] + 4);
|
||||
#else
|
||||
// SACTION
|
||||
const int32_t action_frames = SACTION_NUMFRAMES(vm.g_t);
|
||||
const int32_t action_incval = SACTION_INCVAL(vm.g_t);
|
||||
const int32_t action_delay = SACTION_DELAY(vm.g_t);
|
||||
#endif
|
||||
vm.g_sp->lotag += TICSPERFRAME;
|
||||
|
||||
if (vm.g_sp->lotag > *(script + vm.g_t[4] + 4))
|
||||
if (vm.g_sp->lotag > action_delay)
|
||||
{
|
||||
vm.g_t[2]++;
|
||||
vm.g_sp->lotag = 0;
|
||||
|
||||
vm.g_t[3] += *(script + vm.g_t[4] + 3);
|
||||
vm.g_t[3] += action_incval;
|
||||
}
|
||||
|
||||
if (klabs(vm.g_t[3]) >= klabs(*(script + vm.g_t[4] + 1) * *(script + vm.g_t[4] + 3)))
|
||||
if (klabs(vm.g_t[3]) >= klabs(action_frames * action_incval))
|
||||
vm.g_t[3] = 0;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue