mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-27 09:20:51 +00:00
This probably adds support for saving game arrays into map states. Probably.
git-svn-id: https://svn.eduke32.com/eduke32@5834 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
638312e7f9
commit
bd628ea2f7
1 changed files with 100 additions and 58 deletions
|
@ -725,7 +725,7 @@ dead:
|
||||||
|
|
||||||
if (vm.pSprite->xvel || vm.pSprite->zvel)
|
if (vm.pSprite->xvel || vm.pSprite->zvel)
|
||||||
{
|
{
|
||||||
int nXvel = vm.pSprite->xvel;
|
int spriteXvel = vm.pSprite->xvel;
|
||||||
int angDiff = vm.pSprite->ang;
|
int angDiff = vm.pSprite->ang;
|
||||||
|
|
||||||
if (badguyp && vm.pSprite->picnum != ROTATEGUN)
|
if (badguyp && vm.pSprite->picnum != ROTATEGUN)
|
||||||
|
@ -796,7 +796,7 @@ dead:
|
||||||
|
|
||||||
if (vm.playerDist < 960 && vm.pSprite->xrepeat > 16)
|
if (vm.playerDist < 960 && vm.pSprite->xrepeat > 16)
|
||||||
{
|
{
|
||||||
nXvel = -(1024 - vm.playerDist);
|
spriteXvel = -(1024 - vm.playerDist);
|
||||||
angDiff = getangle(vm.pPlayer->pos.x - vm.pSprite->x, vm.pPlayer->pos.y - vm.pSprite->y);
|
angDiff = getangle(vm.pPlayer->pos.x - vm.pSprite->x, vm.pPlayer->pos.y - vm.pSprite->y);
|
||||||
|
|
||||||
if (vm.playerDist < 512)
|
if (vm.playerDist < 512)
|
||||||
|
@ -819,7 +819,7 @@ dead:
|
||||||
{
|
{
|
||||||
if (AC_COUNT(vm.pData) & 1)
|
if (AC_COUNT(vm.pData) & 1)
|
||||||
return;
|
return;
|
||||||
nXvel <<= 1;
|
spriteXvel <<= 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -827,8 +827,8 @@ dead:
|
||||||
if (vm.pSprite->z < actor[vm.spriteNum].ceilingz+ZOFFSET5)
|
if (vm.pSprite->z < actor[vm.spriteNum].ceilingz+ZOFFSET5)
|
||||||
vm.pSprite->z = actor[vm.spriteNum].ceilingz+ZOFFSET5;
|
vm.pSprite->z = actor[vm.spriteNum].ceilingz+ZOFFSET5;
|
||||||
|
|
||||||
vec3_t const vect = { (nXvel * (sintable[(angDiff + 512) & 2047])) >> 14,
|
vec3_t const vect = { (spriteXvel * (sintable[(angDiff + 512) & 2047])) >> 14,
|
||||||
(nXvel * (sintable[angDiff & 2047])) >> 14, vm.pSprite->zvel };
|
(spriteXvel * (sintable[angDiff & 2047])) >> 14, vm.pSprite->zvel };
|
||||||
|
|
||||||
actor[vm.spriteNum].movflag = A_MoveSprite(vm.spriteNum, &vect, (A_CheckSpriteFlags(vm.spriteNum, SFLAG_NOCLIP) ? 0 : CLIPMASK0));
|
actor[vm.spriteNum].movflag = A_MoveSprite(vm.spriteNum, &vect, (A_CheckSpriteFlags(vm.spriteNum, SFLAG_NOCLIP) ? 0 : CLIPMASK0));
|
||||||
}
|
}
|
||||||
|
@ -941,14 +941,14 @@ static int32_t A_GetWaterZOffset(int spriteNum)
|
||||||
|
|
||||||
static void VM_Fall(int spriteNum, spritetype *pSprite)
|
static void VM_Fall(int spriteNum, spritetype *pSprite)
|
||||||
{
|
{
|
||||||
int nGravity = g_spriteGravity;
|
int spriteGravity = g_spriteGravity;
|
||||||
|
|
||||||
pSprite->xoffset = pSprite->yoffset = 0;
|
pSprite->xoffset = pSprite->yoffset = 0;
|
||||||
|
|
||||||
if (sector[pSprite->sectnum].lotag == ST_2_UNDERWATER || EDUKE32_PREDICT_FALSE(G_CheckForSpaceCeiling(pSprite->sectnum)))
|
if (sector[pSprite->sectnum].lotag == ST_2_UNDERWATER || EDUKE32_PREDICT_FALSE(G_CheckForSpaceCeiling(pSprite->sectnum)))
|
||||||
nGravity = g_spriteGravity/6;
|
spriteGravity = g_spriteGravity/6;
|
||||||
else if (EDUKE32_PREDICT_FALSE(G_CheckForSpaceFloor(pSprite->sectnum)))
|
else if (EDUKE32_PREDICT_FALSE(G_CheckForSpaceFloor(pSprite->sectnum)))
|
||||||
nGravity = 0;
|
spriteGravity = 0;
|
||||||
|
|
||||||
if (!actor[spriteNum].cgg-- || (sector[pSprite->sectnum].floorstat&2))
|
if (!actor[spriteNum].cgg-- || (sector[pSprite->sectnum].floorstat&2))
|
||||||
{
|
{
|
||||||
|
@ -959,8 +959,8 @@ static void VM_Fall(int spriteNum, spritetype *pSprite)
|
||||||
if (pSprite->z < actor[spriteNum].floorz-ZOFFSET)
|
if (pSprite->z < actor[spriteNum].floorz-ZOFFSET)
|
||||||
{
|
{
|
||||||
// Free fall.
|
// Free fall.
|
||||||
pSprite->zvel = min(pSprite->zvel+nGravity, ACTOR_MAXFALLINGZVEL);
|
pSprite->zvel = min(pSprite->zvel+spriteGravity, ACTOR_MAXFALLINGZVEL);
|
||||||
int32_t newZ = pSprite->z + pSprite->zvel;
|
int newZ = pSprite->z + pSprite->zvel;
|
||||||
|
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
if (yax_getbunch(pSprite->sectnum, YAX_FLOOR) >= 0 &&
|
if (yax_getbunch(pSprite->sectnum, YAX_FLOOR) >= 0 &&
|
||||||
|
@ -976,7 +976,7 @@ static void VM_Fall(int spriteNum, spritetype *pSprite)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Preliminary new z position of the actor.
|
// Preliminary new z position of the actor.
|
||||||
int32_t newZ = actor[spriteNum].floorz - ZOFFSET;
|
int newZ = actor[spriteNum].floorz - ZOFFSET;
|
||||||
|
|
||||||
if (A_CheckEnemySprite(pSprite) || (pSprite->picnum == APLAYER && pSprite->owner >= 0))
|
if (A_CheckEnemySprite(pSprite) || (pSprite->picnum == APLAYER && pSprite->owner >= 0))
|
||||||
{
|
{
|
||||||
|
@ -1274,12 +1274,12 @@ skip_check:
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
int nDist = 768;
|
int dist = 768;
|
||||||
int angDiff = 16;
|
int angDiff = 16;
|
||||||
|
|
||||||
if (A_CheckEnemySprite(vm.pSprite) && vm.pSprite->xrepeat > 56)
|
if (A_CheckEnemySprite(vm.pSprite) && vm.pSprite->xrepeat > 56)
|
||||||
{
|
{
|
||||||
nDist = 3084;
|
dist = 3084;
|
||||||
angDiff = 48;
|
angDiff = 48;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1297,12 +1297,12 @@ skip_check:
|
||||||
vm.pSprite->ang -= x; \
|
vm.pSprite->ang -= x; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
if (tw > nDist)
|
if (tw > dist)
|
||||||
{
|
{
|
||||||
CHECK(temphit);
|
CHECK(temphit);
|
||||||
CHECK2(angDiff);
|
CHECK2(angDiff);
|
||||||
|
|
||||||
if (tw > nDist)
|
if (tw > dist)
|
||||||
{
|
{
|
||||||
CHECK(temphit);
|
CHECK(temphit);
|
||||||
CHECK2(-angDiff);
|
CHECK2(-angDiff);
|
||||||
|
@ -5771,6 +5771,39 @@ void A_LoadActor(int32_t spriteNum)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
void VM_UpdateAnim(int spriteNum, int32_t *pData)
|
||||||
|
{
|
||||||
|
#if !defined LUNATIC
|
||||||
|
intptr_t const actionofs = AC_ACTION_ID(pData);
|
||||||
|
intptr_t const *actionptr = (actionofs != 0 && actionofs + 4u < (unsigned) g_scriptSize) ? &apScript[actionofs] : NULL;
|
||||||
|
|
||||||
|
if (actionptr != NULL)
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
#if !defined LUNATIC
|
||||||
|
int const action_frames = actionptr[1];
|
||||||
|
int const action_incval = actionptr[3];
|
||||||
|
int const action_delay = actionptr[4];
|
||||||
|
#else
|
||||||
|
int const action_frames = actor[spriteNum].ac.numframes;
|
||||||
|
int const action_incval = actor[spriteNum].ac.incval;
|
||||||
|
int const action_delay = actor[spriteNum].ac.delay;
|
||||||
|
#endif
|
||||||
|
uint16_t *actionticsptr = &AC_ACTIONTICS(&sprite[spriteNum], &actor[spriteNum]);
|
||||||
|
*actionticsptr += TICSPERFRAME;
|
||||||
|
|
||||||
|
if (*actionticsptr > action_delay)
|
||||||
|
{
|
||||||
|
*actionticsptr = 0;
|
||||||
|
AC_ACTION_COUNT(pData)++;
|
||||||
|
AC_CURFRAME(pData) += action_incval;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (klabs(AC_CURFRAME(pData)) >= klabs(action_frames * action_incval))
|
||||||
|
AC_CURFRAME(pData) = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// NORECURSE
|
// NORECURSE
|
||||||
void A_Execute(int spriteNum, int playerNum, int32_t playerDist)
|
void A_Execute(int spriteNum, int playerNum, int32_t playerDist)
|
||||||
{
|
{
|
||||||
|
@ -5781,8 +5814,6 @@ void A_Execute(int spriteNum, int playerNum, int32_t playerDist)
|
||||||
|
|
||||||
#ifdef LUNATIC
|
#ifdef LUNATIC
|
||||||
int32_t killit=0;
|
int32_t killit=0;
|
||||||
#else
|
|
||||||
intptr_t actionofs, *actionptr;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -5805,35 +5836,7 @@ void A_Execute(int spriteNum, int playerNum, int32_t playerDist)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if !defined LUNATIC
|
VM_UpdateAnim(vm.spriteNum, vm.pData);
|
||||||
actionofs = AC_ACTION_ID(vm.pData);
|
|
||||||
actionptr = (actionofs != 0 && actionofs + 4u < (unsigned)g_scriptSize) ? &apScript[actionofs] : NULL;
|
|
||||||
|
|
||||||
if (actionptr != NULL)
|
|
||||||
#endif
|
|
||||||
{
|
|
||||||
#if !defined LUNATIC
|
|
||||||
int const action_frames = actionptr[1];
|
|
||||||
int const action_incval = actionptr[3];
|
|
||||||
int const action_delay = actionptr[4];
|
|
||||||
#else
|
|
||||||
int const action_frames = actor[vm.spriteNum].ac.numframes;
|
|
||||||
int const action_incval = actor[vm.spriteNum].ac.incval;
|
|
||||||
int const action_delay = actor[vm.spriteNum].ac.delay;
|
|
||||||
#endif
|
|
||||||
uint16_t *actionticsptr = &AC_ACTIONTICS(vm.pSprite, &actor[vm.spriteNum]);
|
|
||||||
*actionticsptr += TICSPERFRAME;
|
|
||||||
|
|
||||||
if (*actionticsptr > action_delay)
|
|
||||||
{
|
|
||||||
*actionticsptr = 0;
|
|
||||||
AC_ACTION_COUNT(vm.pData)++;
|
|
||||||
AC_CURFRAME(vm.pData) += action_incval;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (klabs(AC_CURFRAME(vm.pData)) >= klabs(action_frames * action_incval))
|
|
||||||
AC_CURFRAME(vm.pData) = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef LUNATIC
|
#ifdef LUNATIC
|
||||||
int const picnum = vm.pSprite->picnum;
|
int const picnum = vm.pSprite->picnum;
|
||||||
|
@ -6016,6 +6019,27 @@ void G_SaveMapState(void)
|
||||||
}
|
}
|
||||||
else save->vars[i] = (intptr_t *)aGameVars[i].global;
|
else save->vars[i] = (intptr_t *)aGameVars[i].global;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (bssize_t i=g_gameArrayCount-1; i>=0; i--)
|
||||||
|
{
|
||||||
|
if ((aGameArrays[i].flags & GAMEARRAY_RESTORE) == 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
int size;
|
||||||
|
|
||||||
|
switch (aGameArrays[i].flags & (GAMEARRAY_OFCHAR | GAMEARRAY_OFSHORT | GAMEARRAY_OFINT))
|
||||||
|
{
|
||||||
|
case GAMEARRAY_OFCHAR: size = sizeof(uint8_t); break;
|
||||||
|
case GAMEARRAY_OFSHORT: size = sizeof(uint16_t); break;
|
||||||
|
case GAMEARRAY_OFINT: size = sizeof(uint32_t); break;
|
||||||
|
default: size = sizeof(uintptr_t); break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!save->arrays[i])
|
||||||
|
save->arrays[i] = (intptr_t *)Xaligned_alloc(16, aGameArrays[i].size * size);
|
||||||
|
|
||||||
|
Bmemcpy(&save->arrays[i][0], &aGameArrays[i].pValues[0], aGameArrays[i].size * size);
|
||||||
|
}
|
||||||
#else
|
#else
|
||||||
int32_t slen;
|
int32_t slen;
|
||||||
const char *svcode = El_SerializeGamevars(&slen, levelNum);
|
const char *svcode = El_SerializeGamevars(&slen, levelNum);
|
||||||
|
@ -6132,6 +6156,24 @@ void G_RestoreMapState(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
Gv_RefreshPointers();
|
Gv_RefreshPointers();
|
||||||
|
|
||||||
|
for (bssize_t i=g_gameArrayCount-1; i>=0; i--)
|
||||||
|
{
|
||||||
|
if ((aGameArrays[i].flags & GAMEARRAY_RESTORE) == 0 || !pSavedState->arrays[i])
|
||||||
|
continue;
|
||||||
|
|
||||||
|
int size;
|
||||||
|
|
||||||
|
switch (aGameArrays[i].flags & (GAMEARRAY_OFCHAR | GAMEARRAY_OFSHORT | GAMEARRAY_OFINT))
|
||||||
|
{
|
||||||
|
case GAMEARRAY_OFCHAR: size = sizeof(uint8_t); break;
|
||||||
|
case GAMEARRAY_OFSHORT: size = sizeof(uint16_t); break;
|
||||||
|
case GAMEARRAY_OFINT: size = sizeof(uint32_t); break;
|
||||||
|
default: size = sizeof(uintptr_t); break;
|
||||||
|
}
|
||||||
|
|
||||||
|
Bmemcpy(&aGameArrays[i].pValues[0], &pSavedState->arrays[i][0], aGameArrays[i].size * size);
|
||||||
|
}
|
||||||
#else
|
#else
|
||||||
if (pSavedState->savecode)
|
if (pSavedState->savecode)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue