mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +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.
|
// this is the same crap as in game.c's tspr manipulation. puke.
|
||||||
#define LIGHTRAD (s->yrepeat * tilesizy[s->picnum+LIGHTRAD_PICOFS])
|
#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_DUMMYPLAYER 13
|
||||||
#define STAT_LIGHT 14
|
#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
|
// Defines the motion characteristics of an actor
|
||||||
enum amoveflags_t {
|
enum amoveflags_t {
|
||||||
face_player = 1,
|
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)
|
void G_DoSpriteAnimations(int32_t x,int32_t y,int32_t a,int32_t smoothratio)
|
||||||
{
|
{
|
||||||
int32_t i, j, k, p, sect;
|
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;
|
spritetype *s,*t;
|
||||||
int32_t switchpic;
|
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()
|
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
|
//is the perfect time to animate sprites
|
||||||
t = &tsprite[j];
|
t = &tsprite[j];
|
||||||
i = t->owner;
|
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;
|
sect = s->sectnum;
|
||||||
t1 = T2;
|
t_data1 = T2;
|
||||||
t3 = T4;
|
t_data3 = T4;
|
||||||
t4 = T5;
|
#if 1 // ndef LUNATIC
|
||||||
|
t_data4 = T5; // SACTION
|
||||||
|
#else
|
||||||
|
tptr = &actor[i].t_data;
|
||||||
|
#endif
|
||||||
|
|
||||||
switchpic = s->picnum;
|
switchpic = s->picnum;
|
||||||
//some special cases because dynamictostatic system can't handle addition to constants
|
//some special cases because dynamictostatic system can't handle addition to constants
|
||||||
if ((s->picnum >= SCRAP6)&&(s->picnum<=SCRAP6+7))
|
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;
|
else t->cstat &= ~4;
|
||||||
|
|
||||||
if (klabs(t3) > 64) k += 7;
|
if (klabs(t_data3) > 64) k += 7;
|
||||||
t->picnum = RECON+k;
|
t->picnum = RECON+k;
|
||||||
|
|
||||||
break;
|
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)
|
if (g_player[p].ps->newowner > -1)
|
||||||
{
|
{
|
||||||
t4 = *(actorscrptr[APLAYER]+1);
|
#if 1 // ndef LUNATIC
|
||||||
t3 = 0;
|
t_data4 = *(actorscrptr[APLAYER]+1);
|
||||||
t1 = *(actorscrptr[APLAYER]+2);
|
#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)
|
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;
|
goto skip;
|
||||||
|
|
||||||
l = *(script + t4 + 2);
|
l = *(script + t_data4 + 2);
|
||||||
|
#else
|
||||||
|
l = SACTION_VIEWTYPE(tptr);
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
if (getrendermode() >= 3 && usemodels && md_tilehasmodel(s->picnum,t->pal) >= 0 && !(spriteext[i].flags&SPREXT_NOTMD))
|
if (getrendermode() >= 3 && usemodels && md_tilehasmodel(s->picnum,t->pal) >= 0 && !(spriteext[i].flags&SPREXT_NOTMD))
|
||||||
|
@ -6665,7 +6682,11 @@ PALONLY:
|
||||||
break;
|
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)
|
if (l > 0)
|
||||||
while (tilesizx[t->picnum] == 0 && t->picnum > 0)
|
while (tilesizx[t->picnum] == 0 && t->picnum > 0)
|
||||||
|
@ -6824,7 +6845,7 @@ skip:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case WATERSPLASH2__STATIC:
|
case WATERSPLASH2__STATIC:
|
||||||
t->picnum = WATERSPLASH2+t1;
|
t->picnum = WATERSPLASH2+t_data1;
|
||||||
break;
|
break;
|
||||||
case SHELL__STATIC:
|
case SHELL__STATIC:
|
||||||
t->picnum = s->picnum+(T1&1);
|
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... */
|
/* Helixhorned: let's do away with intptr_t's... */
|
||||||
if ((unsigned)vm.g_t[4] + 4 < (unsigned)g_scriptSize)
|
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;
|
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_t[2]++;
|
||||||
vm.g_sp->lotag = 0;
|
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;
|
vm.g_t[3] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue