mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-15 12:10:53 +00:00
- made more parts of USER serialization friendly.
This commit is contained in:
parent
dcb393bc44
commit
cd45a1f035
7 changed files with 50 additions and 45 deletions
|
@ -1451,10 +1451,12 @@ public:
|
||||||
return Ptr;
|
return Ptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if 0 // this is too dangerous.
|
||||||
operator T* () const
|
operator T* () const
|
||||||
{
|
{
|
||||||
return Ptr;
|
return Ptr;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void Alloc()
|
void Alloc()
|
||||||
{
|
{
|
||||||
|
|
|
@ -1098,7 +1098,7 @@ typedef struct
|
||||||
STATEp *Dive;
|
STATEp *Dive;
|
||||||
} ACTOR_ACTION_SET,*ACTOR_ACTION_SETp;
|
} ACTOR_ACTION_SET,*ACTOR_ACTION_SETp;
|
||||||
|
|
||||||
typedef struct
|
struct ROTATOR
|
||||||
{
|
{
|
||||||
int pos; // current position - always moves toward tgt
|
int pos; // current position - always moves toward tgt
|
||||||
int open_dest; // destination of open position
|
int open_dest; // destination of open position
|
||||||
|
@ -1106,10 +1106,27 @@ typedef struct
|
||||||
int speed; // speed of movement
|
int speed; // speed of movement
|
||||||
int orig_speed; // original speed - vel jacks with speed
|
int orig_speed; // original speed - vel jacks with speed
|
||||||
int vel; // velocity adjuments
|
int vel; // velocity adjuments
|
||||||
int num_walls; // save off positions of walls for rotator
|
|
||||||
int *origx;
|
TArray<int> origX;
|
||||||
int *origy;
|
TArray<int> origY;
|
||||||
} ROTATOR, *ROTATORp;
|
|
||||||
|
void SetNumWalls(int num)
|
||||||
|
{
|
||||||
|
origX.Resize(num);
|
||||||
|
origY.Resize(num);
|
||||||
|
memset(origX.Data(), 0, num * sizeof(int));
|
||||||
|
memset(origY.Data(), 0, num * sizeof(int));
|
||||||
|
}
|
||||||
|
|
||||||
|
void ClearWalls()
|
||||||
|
{
|
||||||
|
origX.Reset();
|
||||||
|
origY.Reset();
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
using ROTATORp = ROTATOR*;
|
||||||
|
|
||||||
//
|
//
|
||||||
// User Extension record
|
// User Extension record
|
||||||
|
@ -1133,8 +1150,7 @@ struct USER
|
||||||
TPointer<ROTATOR> rotator;
|
TPointer<ROTATOR> rotator;
|
||||||
|
|
||||||
// wall vars for lighting
|
// wall vars for lighting
|
||||||
int WallCount;
|
TArray<int8_t> WallShade;
|
||||||
int8_t* WallShade; // malloced - save off wall shades for lighting
|
|
||||||
|
|
||||||
WALLp WallP; // operate on wall instead of sprite
|
WALLp WallP; // operate on wall instead of sprite
|
||||||
STATEp State;
|
STATEp State;
|
||||||
|
|
|
@ -78,8 +78,8 @@ void SectorLightShade(SPRITEp sp, short intensity)
|
||||||
// change wall
|
// change wall
|
||||||
if (!TEST_BOOL4(sp))
|
if (!TEST_BOOL4(sp))
|
||||||
{
|
{
|
||||||
ASSERT(User[sp - sprite] && User[sp - sprite]->WallShade);
|
ASSERT(User[sp - sprite] && User[sp - sprite]->WallShade.Data());
|
||||||
wall_shade = User[sp - sprite]->WallShade;
|
wall_shade = User[sp - sprite]->WallShade.Data();
|
||||||
|
|
||||||
startwall = sector[sp->sectnum].wallptr;
|
startwall = sector[sp->sectnum].wallptr;
|
||||||
endwall = startwall + sector[sp->sectnum].wallnum - 1;
|
endwall = startwall + sector[sp->sectnum].wallnum - 1;
|
||||||
|
|
|
@ -50,7 +50,7 @@ void ReverseRotator(short SpriteNum)
|
||||||
USERp u = User[SpriteNum];
|
USERp u = User[SpriteNum];
|
||||||
ROTATORp r;
|
ROTATORp r;
|
||||||
|
|
||||||
r = u->rotator;
|
r = u->rotator.Data();
|
||||||
|
|
||||||
// if paused go ahead and start it up again
|
// if paused go ahead and start it up again
|
||||||
if (u->Tics)
|
if (u->Tics)
|
||||||
|
@ -101,7 +101,7 @@ void SetRotatorActive(short SpriteNum)
|
||||||
SPRITEp sp = u->SpriteP;
|
SPRITEp sp = u->SpriteP;
|
||||||
ROTATORp r;
|
ROTATORp r;
|
||||||
|
|
||||||
r = u->rotator;
|
r = u->rotator.Data();
|
||||||
|
|
||||||
DoRotatorSetInterp(SpriteNum);
|
DoRotatorSetInterp(SpriteNum);
|
||||||
|
|
||||||
|
@ -320,7 +320,7 @@ int DoRotatorMove(short SpriteNum)
|
||||||
int dist,closest;
|
int dist,closest;
|
||||||
bool kill = false;
|
bool kill = false;
|
||||||
|
|
||||||
r = u->rotator;
|
r = u->rotator.Data();
|
||||||
|
|
||||||
// Example - ang pos moves from 0 to 512 <<OR>> from 0 to -512
|
// Example - ang pos moves from 0 to 512 <<OR>> from 0 to -512
|
||||||
|
|
||||||
|
@ -416,7 +416,7 @@ int DoRotatorMove(short SpriteNum)
|
||||||
// move points
|
// move points
|
||||||
for (w = startwall, ndx = 0; w <= endwall; w++)
|
for (w = startwall, ndx = 0; w <= endwall; w++)
|
||||||
{
|
{
|
||||||
vec2_t const orig = { r->origx[ndx], r->origy[ndx] };
|
vec2_t const orig = { r->origX[ndx], r->origY[ndx] };
|
||||||
rotatepoint(pivot->pos.vec2, orig, r->pos, &nxy);
|
rotatepoint(pivot->pos.vec2, orig, r->pos, &nxy);
|
||||||
|
|
||||||
dragpoint(w, nxy.x, nxy.y, 0);
|
dragpoint(w, nxy.x, nxy.y, 0);
|
||||||
|
|
|
@ -371,9 +371,10 @@ bool GameInterface::SaveGame()
|
||||||
|
|
||||||
MWRITE(u,sizeof(USER),1,fil);
|
MWRITE(u,sizeof(USER),1,fil);
|
||||||
|
|
||||||
|
#if 0
|
||||||
if (u->WallShade)
|
if (u->WallShade)
|
||||||
{
|
{
|
||||||
MWRITE(u->WallShade,sizeof(*u->WallShade)*u->WallCount,1,fil);
|
MWRITE(u->WallShade, sizeof(*u->WallShade) * u->WallCount, 1, fil);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (u->rotator)
|
if (u->rotator)
|
||||||
|
@ -384,6 +385,7 @@ bool GameInterface::SaveGame()
|
||||||
if (u->rotator->origy)
|
if (u->rotator->origy)
|
||||||
MWRITE(u->rotator->origy,sizeof(*u->rotator->origy)*u->rotator->num_walls,1,fil);
|
MWRITE(u->rotator->origy,sizeof(*u->rotator->origy)*u->rotator->num_walls,1,fil);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
saveisshot |= SaveSymDataInfo(fil, u->WallP);
|
saveisshot |= SaveSymDataInfo(fil, u->WallP);
|
||||||
assert(!saveisshot);
|
assert(!saveisshot);
|
||||||
|
@ -753,10 +755,11 @@ bool GameInterface::LoadGame()
|
||||||
MREAD(u,sizeof(USER),1,fil);
|
MREAD(u,sizeof(USER),1,fil);
|
||||||
memset((void*)&u->rotator, 0, sizeof(u->rotator));
|
memset((void*)&u->rotator, 0, sizeof(u->rotator));
|
||||||
|
|
||||||
|
#if 0
|
||||||
if (u->WallShade)
|
if (u->WallShade)
|
||||||
{
|
{
|
||||||
u->WallShade = (int8_t*)CallocMem(u->WallCount * sizeof(*u->WallShade), 1);
|
u->WallShade = (int8_t*)CallocMem(u->WallCount * sizeof(*u->WallShade), 1);
|
||||||
MREAD(u->WallShade,sizeof(*u->WallShade)*u->WallCount,1,fil);
|
MREAD(u->WallShade, sizeof(*u->WallShade) * u->WallCount, 1, fil);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (u->rotator)
|
if (u->rotator)
|
||||||
|
@ -775,6 +778,7 @@ bool GameInterface::LoadGame()
|
||||||
MREAD(u->rotator->origy,sizeof(*u->rotator->origy)*u->rotator->num_walls,1,fil);
|
MREAD(u->rotator->origy,sizeof(*u->rotator->origy)*u->rotator->num_walls,1,fil);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
saveisshot |= LoadSymDataInfo(fil, (void **)&u->WallP);
|
saveisshot |= LoadSymDataInfo(fil, (void **)&u->WallP);
|
||||||
saveisshot |= LoadSymDataInfo(fil, (void **)&u->State);
|
saveisshot |= LoadSymDataInfo(fil, (void **)&u->State);
|
||||||
|
|
|
@ -44,7 +44,7 @@ void ReverseSlidor(short SpriteNum)
|
||||||
USERp u = User[SpriteNum];
|
USERp u = User[SpriteNum];
|
||||||
ROTATORp r;
|
ROTATORp r;
|
||||||
|
|
||||||
r = u->rotator;
|
r = u->rotator.Data();
|
||||||
|
|
||||||
// if paused go ahead and start it up again
|
// if paused go ahead and start it up again
|
||||||
if (u->Tics)
|
if (u->Tics)
|
||||||
|
@ -96,7 +96,7 @@ void SetSlidorActive(short SpriteNum)
|
||||||
SPRITEp sp = u->SpriteP;
|
SPRITEp sp = u->SpriteP;
|
||||||
ROTATORp r;
|
ROTATORp r;
|
||||||
|
|
||||||
r = u->rotator;
|
r = u->rotator.Data();
|
||||||
|
|
||||||
DoSlidorInterp(SpriteNum, StartInterpolation);
|
DoSlidorInterp(SpriteNum, StartInterpolation);
|
||||||
|
|
||||||
|
@ -543,7 +543,7 @@ int DoSlidorMove(short SpriteNum)
|
||||||
int old_pos;
|
int old_pos;
|
||||||
bool kill = false;
|
bool kill = false;
|
||||||
|
|
||||||
r = u->rotator;
|
r = u->rotator.Data();
|
||||||
|
|
||||||
// Example - ang pos moves from 0 to 512 <<OR>> from 0 to -512
|
// Example - ang pos moves from 0 to 512 <<OR>> from 0 to -512
|
||||||
|
|
||||||
|
|
|
@ -642,12 +642,6 @@ KillSprite(int16_t SpriteNum)
|
||||||
PLAYERp pp;
|
PLAYERp pp;
|
||||||
short pnum;
|
short pnum;
|
||||||
|
|
||||||
if (u->WallShade)
|
|
||||||
{
|
|
||||||
FreeMem(u->WallShade);
|
|
||||||
u->WallShade = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
// doing a MissileSetPos - don't allow killing
|
// doing a MissileSetPos - don't allow killing
|
||||||
if (TEST(u->Flags, SPR_SET_POS_DONT_KILL))
|
if (TEST(u->Flags, SPR_SET_POS_DONT_KILL))
|
||||||
return;
|
return;
|
||||||
|
@ -784,15 +778,7 @@ KillSprite(int16_t SpriteNum)
|
||||||
SetSuicide(u->flame);
|
SetSuicide(u->flame);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (u->rotator)
|
|
||||||
{
|
|
||||||
if (u->rotator->origx)
|
|
||||||
FreeMem(u->rotator->origx);
|
|
||||||
if (u->rotator->origy)
|
|
||||||
FreeMem(u->rotator->origy);
|
|
||||||
|
|
||||||
u->rotator.Clear();
|
u->rotator.Clear();
|
||||||
}
|
|
||||||
|
|
||||||
FreeUser(SpriteNum);
|
FreeUser(SpriteNum);
|
||||||
}
|
}
|
||||||
|
@ -909,7 +895,6 @@ SpawnUser(short SpriteNum, short id, STATEp state)
|
||||||
u->SpriteNum = SpriteNum;
|
u->SpriteNum = SpriteNum;
|
||||||
u->WaitTics = 0;
|
u->WaitTics = 0;
|
||||||
u->OverlapZ = Z(4);
|
u->OverlapZ = Z(4);
|
||||||
u->WallShade = NULL;
|
|
||||||
u->bounce = 0;
|
u->bounce = 0;
|
||||||
|
|
||||||
u->motion_blur_num = 0;
|
u->motion_blur_num = 0;
|
||||||
|
@ -2405,21 +2390,19 @@ SpriteSetup(void)
|
||||||
wallcount++;
|
wallcount++;
|
||||||
|
|
||||||
u->rotator.Alloc();
|
u->rotator.Alloc();
|
||||||
u->rotator->num_walls = wallcount;
|
|
||||||
u->rotator->open_dest = SP_TAG5(sp);
|
u->rotator->open_dest = SP_TAG5(sp);
|
||||||
u->rotator->speed = SP_TAG7(sp);
|
u->rotator->speed = SP_TAG7(sp);
|
||||||
u->rotator->vel = SP_TAG8(sp);
|
u->rotator->vel = SP_TAG8(sp);
|
||||||
u->rotator->pos = 0; // closed
|
u->rotator->pos = 0; // closed
|
||||||
u->rotator->tgt = u->rotator->open_dest; // closed
|
u->rotator->tgt = u->rotator->open_dest; // closed
|
||||||
u->rotator->origx = (int*)CallocMem(sizeof(u->rotator->origx) * wallcount, 1);
|
u->rotator->SetNumWalls(wallcount);
|
||||||
u->rotator->origy = (int*)CallocMem(sizeof(u->rotator->origy) * wallcount, 1);
|
|
||||||
|
|
||||||
u->rotator->orig_speed = u->rotator->speed;
|
u->rotator->orig_speed = u->rotator->speed;
|
||||||
|
|
||||||
for (w = startwall, wallcount = 0; w <= endwall; w++)
|
for (w = startwall, wallcount = 0; w <= endwall; w++)
|
||||||
{
|
{
|
||||||
u->rotator->origx[wallcount] = wall[w].x;
|
u->rotator->origX[wallcount] = wall[w].x;
|
||||||
u->rotator->origy[wallcount] = wall[w].y;
|
u->rotator->origY[wallcount] = wall[w].y;
|
||||||
wallcount++;
|
wallcount++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2466,7 +2449,7 @@ SpriteSetup(void)
|
||||||
u->rotator->vel = SP_TAG8(sp);
|
u->rotator->vel = SP_TAG8(sp);
|
||||||
u->rotator->pos = 0; // closed
|
u->rotator->pos = 0; // closed
|
||||||
u->rotator->tgt = u->rotator->open_dest; // closed
|
u->rotator->tgt = u->rotator->open_dest; // closed
|
||||||
u->rotator->num_walls = 0;
|
u->rotator->ClearWalls();
|
||||||
u->rotator->orig_speed = u->rotator->speed;
|
u->rotator->orig_speed = u->rotator->speed;
|
||||||
|
|
||||||
SET(u->Flags, SPR_ACTIVE);
|
SET(u->Flags, SPR_ACTIVE);
|
||||||
|
@ -2611,8 +2594,8 @@ SpriteSetup(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
User[SpriteNum] = u = SpawnUser(SpriteNum, 0, NULL);
|
User[SpriteNum] = u = SpawnUser(SpriteNum, 0, NULL);
|
||||||
u->WallCount = wallcount;
|
u->WallShade.Resize(wallcount);
|
||||||
wall_shade = u->WallShade = (int8_t*)CallocMem(u->WallCount * sizeof(*u->WallShade), 1);
|
wall_shade = u->WallShade.Data();
|
||||||
|
|
||||||
// save off original wall shades
|
// save off original wall shades
|
||||||
for (w = startwall, wallcount = 0; w <= endwall; w++)
|
for (w = startwall, wallcount = 0; w <= endwall; w++)
|
||||||
|
@ -2667,8 +2650,8 @@ SpriteSetup(void)
|
||||||
// !LIGHT
|
// !LIGHT
|
||||||
// make an wall_shade array and put it in User
|
// make an wall_shade array and put it in User
|
||||||
User[SpriteNum] = u = SpawnUser(SpriteNum, 0, NULL);
|
User[SpriteNum] = u = SpawnUser(SpriteNum, 0, NULL);
|
||||||
u->WallCount = wallcount;
|
u->WallShade.Resize(wallcount);
|
||||||
wall_shade = u->WallShade = (int8_t*)CallocMem(u->WallCount * sizeof(*u->WallShade), 1);
|
wall_shade = u->WallShade.Data();
|
||||||
|
|
||||||
// save off original wall shades
|
// save off original wall shades
|
||||||
for (w = startwall, wallcount = 0; w <= endwall; w++)
|
for (w = startwall, wallcount = 0; w <= endwall; w++)
|
||||||
|
|
Loading…
Reference in a new issue