mirror of
https://github.com/ZDoom/raze-gles.git
synced 2024-12-31 22:00:46 +00:00
- store script code in a dynamic array.
# Conflicts: # source/games/duke/src/zz_game.cpp
This commit is contained in:
parent
b2290cca3f
commit
cb1824ca25
11 changed files with 57 additions and 109 deletions
|
@ -4893,7 +4893,7 @@ void alterang(int a, int g_i, int g_p)
|
|||
int* g_t = hittype[g_i].t_data;
|
||||
auto* g_sp = &sprite[g_i];
|
||||
|
||||
moveptr = apScript + g_t[1];
|
||||
moveptr = &ScriptCode[g_t[1]];
|
||||
|
||||
ticselapsed = (g_t[0]) & 31;
|
||||
|
||||
|
|
|
@ -4030,7 +4030,7 @@ void move_d(int g_i, int g_p, int g_x)
|
|||
return;
|
||||
}
|
||||
|
||||
moveptr = apScript + g_t[1];
|
||||
moveptr = &ScriptCode[g_t[1]];
|
||||
|
||||
if (a & geth) g_sp->xvel += (*moveptr - g_sp->xvel) >> 1;
|
||||
if (a & getv) g_sp->zvel += ((*(moveptr + 1) << 4) - g_sp->zvel) >> 1;
|
||||
|
|
|
@ -4203,7 +4203,7 @@ void move_r(int g_i, int g_p, int g_x)
|
|||
return;
|
||||
}
|
||||
|
||||
moveptr = apScript + g_t[1];
|
||||
moveptr = &ScriptCode[g_t[1]];
|
||||
|
||||
if (a & geth) g_sp->xvel += (*moveptr - g_sp->xvel) >> 1;
|
||||
if (a & getv) g_sp->zvel += ((*(moveptr + 1) << 4) - g_sp->zvel) >> 1;
|
||||
|
|
|
@ -59,9 +59,9 @@ int checking_ifelse;
|
|||
|
||||
//G_EXTERN char tempbuf[MAXSECTORS << 1], buf[1024]; todo - move to compile state. tempbuf gets used nearly everywhere as scratchpad memory.
|
||||
extern char tempbuf[];
|
||||
extern intptr_t* scriptaddress;
|
||||
extern int* labelcode;
|
||||
extern intptr_t* apScript;
|
||||
|
||||
TArray<intptr_t> ScriptCode;
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
//
|
||||
|
@ -375,68 +375,44 @@ void getlabel(void)
|
|||
//
|
||||
//---------------------------------------------------------------------------
|
||||
|
||||
#if 0
|
||||
static void setscriptvalue(int offset, int value)
|
||||
{
|
||||
script[offset] = value;
|
||||
ScriptCode[offset] = value;
|
||||
}
|
||||
|
||||
int scriptpos()
|
||||
{
|
||||
return script.Size();
|
||||
return ScriptCode.Size();
|
||||
}
|
||||
|
||||
static void appendscriptvalue(int value)
|
||||
{
|
||||
script.Push(value);
|
||||
ScriptCode.Push(value);
|
||||
}
|
||||
|
||||
static int popscriptvalue()
|
||||
{
|
||||
int p;
|
||||
script.Pop(p);
|
||||
decltype(ScriptCode)::value_type p;
|
||||
ScriptCode.Pop(p);
|
||||
return p;
|
||||
}
|
||||
|
||||
void pushlabeladdress()
|
||||
{
|
||||
labelcode.Push(script.Size());
|
||||
}
|
||||
|
||||
void reservescriptspace(int space)
|
||||
{
|
||||
script.Reserve(space);
|
||||
ScriptCode.Reserve(space);
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
// TRANSITIONAL Helpers to write to the old script buffer while using the new interface. Allows to test the parser before implementing the rest.
|
||||
void scriptWriteValue(int32_t const value);
|
||||
void scriptWriteAtOffset(int32_t const value, intptr_t addr);
|
||||
void scriptWritePointer(intptr_t const value, intptr_t addr);
|
||||
static void setscriptvalue(int offset, int value)
|
||||
/*
|
||||
void pushlabeladdress()
|
||||
{
|
||||
apScript[offset] = value;
|
||||
labelcode.Push(script.Size());
|
||||
}
|
||||
*/
|
||||
|
||||
static void appendscriptvalue(int value)
|
||||
{
|
||||
*scriptaddress++ = value;
|
||||
}
|
||||
|
||||
static int popscriptvalue()
|
||||
{
|
||||
return *--scriptaddress;
|
||||
}
|
||||
|
||||
int scriptpos()
|
||||
{
|
||||
return int(scriptaddress - apScript);
|
||||
}
|
||||
|
||||
void appendlabeladdress(int offset = 0)
|
||||
{
|
||||
labelcode[labelcnt++] = int(scriptaddress - apScript) + offset;
|
||||
labelcode[labelcnt++] = ScriptCode.Size() + offset;
|
||||
labelcnt++;
|
||||
}
|
||||
|
||||
|
@ -446,14 +422,6 @@ void appendlabelvalue(int value)
|
|||
labelcnt++;
|
||||
}
|
||||
|
||||
void reservescriptspace(int space)
|
||||
{
|
||||
scriptaddress += space;
|
||||
}
|
||||
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
|
@ -753,8 +721,7 @@ int parsecommand()
|
|||
while (keyword() == -1)
|
||||
{
|
||||
transnum();
|
||||
popscriptvalue();
|
||||
j |= *scriptaddress;
|
||||
j |= popscriptvalue();
|
||||
}
|
||||
appendscriptvalue(j);
|
||||
}
|
||||
|
@ -791,9 +758,8 @@ int parsecommand()
|
|||
{
|
||||
popscriptvalue();
|
||||
transnum(); // Volume Number (0/4)
|
||||
popscriptvalue();
|
||||
k = popscriptvalue() - 1;
|
||||
|
||||
k = *scriptaddress - 1;
|
||||
if (k == -1) k = MAXVOLUMES;
|
||||
|
||||
if (k >= 0) // if it's background music
|
||||
|
@ -1037,8 +1003,7 @@ int parsecommand()
|
|||
parsing_event = parsing_actor = scriptpos();
|
||||
|
||||
transnum();
|
||||
popscriptvalue();
|
||||
j = *scriptaddress; // type of event
|
||||
j = popscriptvalue();
|
||||
if (j< 0 || j> EVENT_MAXEVENT)
|
||||
{
|
||||
Printf(TEXTCOLOR_RED " * ERROR!(%s, line %d) Invalid Event ID.\n", fn, line_number);
|
||||
|
@ -1129,7 +1094,7 @@ int parsecommand()
|
|||
{
|
||||
checking_ifelse--;
|
||||
tempscrptr = scriptpos();
|
||||
scriptaddress++; //Leave a spot for the fail location
|
||||
reservescriptspace(1); //Leave a spot for the fail location
|
||||
parsecommand();
|
||||
setscriptvalue(tempscrptr, scriptpos());
|
||||
}
|
||||
|
@ -1304,8 +1269,7 @@ int parsecommand()
|
|||
do
|
||||
{
|
||||
transnum();
|
||||
popscriptvalue();
|
||||
j |= *scriptaddress;
|
||||
j |= popscriptvalue();
|
||||
} while (keyword() == -1);
|
||||
appendscriptvalue(j);
|
||||
goto if_common;
|
||||
|
@ -1405,8 +1369,7 @@ int parsecommand()
|
|||
case concmd_definevolumename:
|
||||
popscriptvalue();
|
||||
transnum();
|
||||
popscriptvalue();
|
||||
j = *scriptaddress;
|
||||
j = popscriptvalue();
|
||||
while (*textptr == ' ' || *textptr == '\t') textptr++;
|
||||
|
||||
i = 0;
|
||||
|
@ -1423,8 +1386,7 @@ int parsecommand()
|
|||
case concmd_defineskillname:
|
||||
popscriptvalue();
|
||||
transnum();
|
||||
popscriptvalue();
|
||||
j = *scriptaddress;
|
||||
j = popscriptvalue();
|
||||
while (*textptr == ' ') textptr++;
|
||||
|
||||
i = 0;
|
||||
|
@ -1442,11 +1404,9 @@ int parsecommand()
|
|||
case concmd_definelevelname:
|
||||
popscriptvalue();
|
||||
transnum();
|
||||
popscriptvalue();
|
||||
j = *scriptaddress;
|
||||
j = popscriptvalue();
|
||||
transnum();
|
||||
popscriptvalue();
|
||||
k = *scriptaddress;
|
||||
k = popscriptvalue();
|
||||
while (*textptr == ' ') textptr++;
|
||||
|
||||
i = 0;
|
||||
|
@ -1490,13 +1450,13 @@ int parsecommand()
|
|||
case concmd_definequote:
|
||||
popscriptvalue();
|
||||
transnum();
|
||||
k = *(scriptaddress - 1);
|
||||
k = popscriptvalue();
|
||||
if (k >= MAXQUOTES)
|
||||
{
|
||||
Printf(TEXTCOLOR_RED " * ERROR!(%s, line %d) Quote number exceeds limit of %d.\n", line_number, MAXQUOTES);
|
||||
errorcount++;
|
||||
}
|
||||
popscriptvalue();
|
||||
|
||||
i = 0;
|
||||
while (*textptr == ' ')
|
||||
textptr++;
|
||||
|
@ -1514,8 +1474,7 @@ int parsecommand()
|
|||
{
|
||||
popscriptvalue();
|
||||
transnum();
|
||||
k = *(scriptaddress - 1);
|
||||
popscriptvalue();
|
||||
k = popscriptvalue();
|
||||
i = 0;
|
||||
while (*textptr == ' ')
|
||||
textptr++;
|
||||
|
@ -1529,20 +1488,15 @@ int parsecommand()
|
|||
parsebuffer.Push(0);
|
||||
|
||||
transnum();
|
||||
int ps = *(scriptaddress - 1);
|
||||
popscriptvalue();
|
||||
int ps = popscriptvalue();
|
||||
transnum();
|
||||
int pe = *(scriptaddress - 1);
|
||||
popscriptvalue();
|
||||
int pe = popscriptvalue();
|
||||
transnum();
|
||||
int pr = *(scriptaddress - 1);
|
||||
popscriptvalue();
|
||||
int pr = popscriptvalue();
|
||||
transnum();
|
||||
int m = *(scriptaddress - 1);
|
||||
popscriptvalue();
|
||||
int m = popscriptvalue();
|
||||
transnum();
|
||||
int vo = *(scriptaddress - 1);
|
||||
popscriptvalue();
|
||||
int vo = popscriptvalue();
|
||||
S_DefineSound(k, parsebuffer.Data(), ps, pe, pr, m, vo, 1.f);
|
||||
return 0;
|
||||
}
|
||||
|
@ -1625,6 +1579,7 @@ int parsecommand()
|
|||
return 0;
|
||||
case concmd_gamestartup:
|
||||
{
|
||||
popscriptvalue();
|
||||
auto parseone = []() { transnum(); return popscriptvalue(); };
|
||||
ud.const_visibility = parseone();
|
||||
impact_damage = parseone();
|
||||
|
@ -1664,7 +1619,6 @@ int parsecommand()
|
|||
max_ammo_amount[14] = parseone();
|
||||
max_ammo_amount[16] = parseone();
|
||||
}
|
||||
scriptaddress++;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
@ -1714,7 +1668,7 @@ void loadcons(const char* filenam)
|
|||
memset(&actorinfo[i], 0, sizeof(actorinfo));
|
||||
}
|
||||
|
||||
apScript = (intptr_t*)Xcalloc(1, g_scriptSize * sizeof(intptr_t));
|
||||
ScriptCode.Clear();
|
||||
|
||||
labelcnt = 0;
|
||||
|
||||
|
@ -1726,7 +1680,7 @@ void loadcons(const char* filenam)
|
|||
|
||||
auto before = I_nsTime();
|
||||
|
||||
scriptaddress = apScript + 1;
|
||||
ScriptCode.Push(0);
|
||||
compilecon(filenam); //Tokenize
|
||||
|
||||
if (userConfig.AddCons) for (FString& m : *userConfig.AddCons.get())
|
||||
|
@ -1744,7 +1698,7 @@ void loadcons(const char* filenam)
|
|||
{
|
||||
auto after = I_nsTime();
|
||||
Printf("Compilation time:%.2f ms, Code Size:%d bytes. %d labels. %d/%d Variables.\n", (after-before) / 1000000.,
|
||||
((scriptaddress - apScript) << 2) - 4,
|
||||
(ScriptCode.Size() << 2) - 4,
|
||||
labelcnt,
|
||||
0,//iGameVarCount,
|
||||
MAXGAMEVARS
|
||||
|
|
|
@ -53,9 +53,6 @@ extern int32_t g_totalLines;
|
|||
extern int warningcount;
|
||||
extern int32_t otherp;
|
||||
|
||||
extern intptr_t *scriptaddress;
|
||||
|
||||
|
||||
int32_t C_AllocQuote(int32_t qnum);
|
||||
void C_InitQuotes(void);
|
||||
|
||||
|
|
|
@ -80,7 +80,7 @@ void parseifelse(int condition)
|
|||
}
|
||||
else
|
||||
{
|
||||
insptr = apScript + *(insptr+1);
|
||||
insptr = &ScriptCode[*(insptr+1)];
|
||||
if(*insptr == 10)
|
||||
{
|
||||
// else...
|
||||
|
@ -278,9 +278,9 @@ int parse(void)
|
|||
case concmd_ai:
|
||||
insptr++;
|
||||
g_t[5] = *insptr;
|
||||
g_t[4] = apScript[g_t[5]]; // Action
|
||||
g_t[1] = apScript[g_t[5] + 1]; // move
|
||||
g_sp->hitag = apScript[g_t[5] + 2]; // Ai
|
||||
g_t[4] = ScriptCode[g_t[5]]; // Action
|
||||
g_t[1] = ScriptCode[g_t[5] + 1]; // move
|
||||
g_sp->hitag = ScriptCode[g_t[5] + 2]; // Ai
|
||||
g_t[0] = g_t[2] = g_t[3] = 0;
|
||||
if (g_sp->hitag & random_angle)
|
||||
g_sp->ang = krand() & 2047;
|
||||
|
@ -307,7 +307,7 @@ int parse(void)
|
|||
hittype[g_i].timetosleep = SLEEPTIME;
|
||||
break;
|
||||
case concmd_else:
|
||||
insptr = apScript + *(insptr + 1);
|
||||
insptr = &ScriptCode[*(insptr + 1)];
|
||||
break;
|
||||
case concmd_addstrength:
|
||||
insptr++;
|
||||
|
@ -826,7 +826,7 @@ int parse(void)
|
|||
case concmd_state:
|
||||
{
|
||||
auto tempscrptr = insptr + 2;
|
||||
insptr = apScript + *(insptr + 1);
|
||||
insptr = &ScriptCode[*(insptr + 1)];
|
||||
while (1) if (parse()) break;
|
||||
insptr = tempscrptr;
|
||||
}
|
||||
|
@ -1517,7 +1517,7 @@ int parse(void)
|
|||
|
||||
default:
|
||||
Printf(TEXTCOLOR_RED "Unrecognized PCode of %ld in parse. Killing current sprite.\n",*insptr);
|
||||
Printf(TEXTCOLOR_RED "Offset=%0lX\n",scriptaddress-apScript);
|
||||
Printf(TEXTCOLOR_RED "Offset=%0lX\n",insptr-ScriptCode.Data());
|
||||
killit_flag = 1;
|
||||
break;
|
||||
}
|
||||
|
@ -1537,7 +1537,7 @@ void execute(int i,int p,int x)
|
|||
g_t = &hittype[g_i].temp_data[0]; // Sprite's 'extra' data
|
||||
|
||||
if (actorinfo[g_sp->picnum].scriptaddress == 0) return;
|
||||
insptr = apScript + 4 + (actorinfo[g_sp->picnum].scriptaddress);
|
||||
insptr = &ScriptCode[4 + (actorinfo[g_sp->picnum].scriptaddress)];
|
||||
|
||||
killit_flag = 0;
|
||||
|
||||
|
@ -1552,7 +1552,7 @@ void execute(int i,int p,int x)
|
|||
if (g_t[4])
|
||||
{
|
||||
// This code was utterly cryptic in the original source.
|
||||
auto ptr = apScript + g_t[4];
|
||||
auto ptr = &ScriptCode[g_t[4]];
|
||||
int numframes = ptr[1];
|
||||
int increment = ptr[3];
|
||||
int delay = ptr[4];
|
||||
|
@ -1649,7 +1649,7 @@ void OnEvent(int iEventID, int p, int i, int x)
|
|||
g_sp = &sprite[g_i];
|
||||
g_t = &hittype[g_i].temp_data[0];
|
||||
|
||||
insptr = apScript + apScriptGameEvent[iEventID];
|
||||
insptr = &ScriptCode[apScriptGameEvent[iEventID]];
|
||||
|
||||
killit_flag = 0;
|
||||
do
|
||||
|
|
|
@ -77,6 +77,7 @@ enum
|
|||
EVENT_MAXEVENT = EVENT_NUMEVENTS - 1
|
||||
};
|
||||
|
||||
extern TArray<intptr_t> ScriptCode;
|
||||
|
||||
|
||||
void OnEvent(int id, int pnum = -1, int snum = -1, int dist = -1);
|
||||
|
|
|
@ -201,9 +201,6 @@ G_EXTERN int16_t ambientlotag[64];
|
|||
G_EXTERN int16_t ambienthitag[64];
|
||||
G_EXTERN uint32_t g_ambientCnt;
|
||||
|
||||
G_EXTERN intptr_t *apScript;
|
||||
G_EXTERN intptr_t *scriptaddress;
|
||||
|
||||
inline int32_t G_HaveActor(int spriteNum)
|
||||
{
|
||||
return actorinfo[spriteNum].scriptaddress != NULL;
|
||||
|
@ -211,7 +208,7 @@ inline int32_t G_HaveActor(int spriteNum)
|
|||
|
||||
inline int32_t G_DefaultActorHealth(int spriteNum) // rename!
|
||||
{
|
||||
return G_HaveActor(spriteNum) ? apScript[actorinfo[spriteNum].scriptaddress] : 0;
|
||||
return G_HaveActor(spriteNum) ? ScriptCode[actorinfo[spriteNum].scriptaddress] : 0;
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -173,7 +173,7 @@ void A_MoveSector(int spriteNum)
|
|||
}
|
||||
|
||||
// NOTE: T5 is AC_ACTION_ID
|
||||
# define LIGHTRAD_PICOFS(i) (T5(i) ? *(apScript + T5(i)) + (*(apScript + T5(i) + 2)) * AC_CURFRAME(actor[i].t_data) : 0)
|
||||
# define LIGHTRAD_PICOFS(i) (T5(i) ? ScriptCode[T5(i)] + ScriptCode[T5(i) + 2] * AC_CURFRAME(actor[i].t_data) : 0)
|
||||
|
||||
// this is the same crap as in game.c's tspr manipulation. puke.
|
||||
// XXX: may access tilesizy out-of-bounds by bad user code.
|
||||
|
|
|
@ -1321,7 +1321,7 @@ static int32_t G_InitActor(int32_t i, int32_t tilenum, int32_t set_movflag_uncon
|
|||
{
|
||||
if (actorinfo[tilenum].scriptaddress)
|
||||
{
|
||||
auto sa = &apScript[actorinfo[tilenum].scriptaddress];
|
||||
auto sa = &ScriptCode[actorinfo[tilenum].scriptaddress];
|
||||
SH(i) = sa[0];
|
||||
AC_ACTION_ID(actor[i].t_data) = sa[1];
|
||||
AC_MOVE_ID(actor[i].t_data) = sa[2];
|
||||
|
@ -5065,7 +5065,7 @@ default_case1:
|
|||
{
|
||||
// Display TILE_APLAYER sprites with action PSTAND when viewed through
|
||||
// a camera.
|
||||
auto aplayer_scr = apScript + actorinfo[TILE_APLAYER].scriptaddress;
|
||||
auto aplayer_scr = &ScriptCode[actorinfo[TILE_APLAYER].scriptaddress];
|
||||
// [0]=strength, [1]=actionofs, [2]=moveofs
|
||||
|
||||
scrofs_action = aplayer_scr[1];
|
||||
|
@ -5269,8 +5269,8 @@ default_case2:
|
|||
if ((unsigned)scrofs_action + ACTION_VIEWTYPE >= (unsigned)g_scriptSize)
|
||||
goto skip;
|
||||
|
||||
int viewtype = apScript[scrofs_action + ACTION_VIEWTYPE];
|
||||
uint16_t const action_flags = apScript[scrofs_action + ACTION_FLAGS];
|
||||
int viewtype = ScriptCode[scrofs_action + ACTION_VIEWTYPE];
|
||||
uint16_t const action_flags = ScriptCode[scrofs_action + ACTION_FLAGS];
|
||||
|
||||
int const invertp = viewtype < 0;
|
||||
l = klabs(viewtype);
|
||||
|
@ -5334,7 +5334,7 @@ default_case2:
|
|||
}
|
||||
}
|
||||
|
||||
t->picnum += frameOffset + apScript[scrofs_action + ACTION_STARTFRAME] + l*curframe;
|
||||
t->picnum += frameOffset + ScriptCode[scrofs_action + ACTION_STARTFRAME] + l*curframe;
|
||||
// XXX: t->picnum can be out-of-bounds by bad user code.
|
||||
|
||||
if (l > 0)
|
||||
|
@ -6515,7 +6515,6 @@ static void G_Cleanup(void)
|
|||
#if 0
|
||||
if (labeltype != (int32_t*)&wall[0]) Xfree(labeltype);
|
||||
#endif
|
||||
Xfree(apScript);
|
||||
|
||||
}
|
||||
|
||||
|
|
|
@ -1077,7 +1077,7 @@ int32_t sv_loadheader(FileReader &fill, int32_t spot, savehead_t *h)
|
|||
return -2;
|
||||
}
|
||||
|
||||
if (h->majorver != SV_MAJOR_VER || h->minorver != SV_MINOR_VER || h->bytever != BYTEVERSION || h->userbytever != ud.userbytever || (apScript != NULL))
|
||||
if (h->majorver != SV_MAJOR_VER || h->minorver != SV_MINOR_VER || h->bytever != BYTEVERSION || h->userbytever != ud.userbytever || ScriptCode.Size())
|
||||
{
|
||||
#ifndef DEBUGGINGAIDS
|
||||
if (havedemo)
|
||||
|
|
Loading…
Reference in a new issue