- store script code in a dynamic array.

# Conflicts:
#	source/games/duke/src/zz_game.cpp
This commit is contained in:
Christoph Oelckers 2020-05-15 11:30:33 +02:00
parent b2290cca3f
commit cb1824ca25
11 changed files with 57 additions and 109 deletions

View file

@ -4893,7 +4893,7 @@ void alterang(int a, int g_i, int g_p)
int* g_t = hittype[g_i].t_data; int* g_t = hittype[g_i].t_data;
auto* g_sp = &sprite[g_i]; auto* g_sp = &sprite[g_i];
moveptr = apScript + g_t[1]; moveptr = &ScriptCode[g_t[1]];
ticselapsed = (g_t[0]) & 31; ticselapsed = (g_t[0]) & 31;

View file

@ -4030,7 +4030,7 @@ void move_d(int g_i, int g_p, int g_x)
return; return;
} }
moveptr = apScript + g_t[1]; moveptr = &ScriptCode[g_t[1]];
if (a & geth) g_sp->xvel += (*moveptr - g_sp->xvel) >> 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; if (a & getv) g_sp->zvel += ((*(moveptr + 1) << 4) - g_sp->zvel) >> 1;

View file

@ -4203,7 +4203,7 @@ void move_r(int g_i, int g_p, int g_x)
return; return;
} }
moveptr = apScript + g_t[1]; moveptr = &ScriptCode[g_t[1]];
if (a & geth) g_sp->xvel += (*moveptr - g_sp->xvel) >> 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; if (a & getv) g_sp->zvel += ((*(moveptr + 1) << 4) - g_sp->zvel) >> 1;

View file

@ -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. //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 char tempbuf[];
extern intptr_t* scriptaddress;
extern int* labelcode; 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) static void setscriptvalue(int offset, int value)
{ {
script[offset] = value; ScriptCode[offset] = value;
} }
int scriptpos() int scriptpos()
{ {
return script.Size(); return ScriptCode.Size();
} }
static void appendscriptvalue(int value) static void appendscriptvalue(int value)
{ {
script.Push(value); ScriptCode.Push(value);
} }
static int popscriptvalue() static int popscriptvalue()
{ {
int p; decltype(ScriptCode)::value_type p;
script.Pop(p); ScriptCode.Pop(p);
return p; return p;
} }
void pushlabeladdress()
{
labelcode.Push(script.Size());
}
void reservescriptspace(int space) void reservescriptspace(int space)
{ {
script.Reserve(space); ScriptCode.Reserve(space);
} }
#else /*
void pushlabeladdress()
// 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)
{ {
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) void appendlabeladdress(int offset = 0)
{ {
labelcode[labelcnt++] = int(scriptaddress - apScript) + offset; labelcode[labelcnt++] = ScriptCode.Size() + offset;
labelcnt++; labelcnt++;
} }
@ -446,14 +422,6 @@ void appendlabelvalue(int value)
labelcnt++; labelcnt++;
} }
void reservescriptspace(int space)
{
scriptaddress += space;
}
#endif
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
@ -753,8 +721,7 @@ int parsecommand()
while (keyword() == -1) while (keyword() == -1)
{ {
transnum(); transnum();
popscriptvalue(); j |= popscriptvalue();
j |= *scriptaddress;
} }
appendscriptvalue(j); appendscriptvalue(j);
} }
@ -791,9 +758,8 @@ int parsecommand()
{ {
popscriptvalue(); popscriptvalue();
transnum(); // Volume Number (0/4) transnum(); // Volume Number (0/4)
popscriptvalue(); k = popscriptvalue() - 1;
k = *scriptaddress - 1;
if (k == -1) k = MAXVOLUMES; if (k == -1) k = MAXVOLUMES;
if (k >= 0) // if it's background music if (k >= 0) // if it's background music
@ -1037,8 +1003,7 @@ int parsecommand()
parsing_event = parsing_actor = scriptpos(); parsing_event = parsing_actor = scriptpos();
transnum(); transnum();
popscriptvalue(); j = popscriptvalue();
j = *scriptaddress; // type of event
if (j< 0 || j> EVENT_MAXEVENT) if (j< 0 || j> EVENT_MAXEVENT)
{ {
Printf(TEXTCOLOR_RED " * ERROR!(%s, line %d) Invalid Event ID.\n", fn, line_number); Printf(TEXTCOLOR_RED " * ERROR!(%s, line %d) Invalid Event ID.\n", fn, line_number);
@ -1129,7 +1094,7 @@ int parsecommand()
{ {
checking_ifelse--; checking_ifelse--;
tempscrptr = scriptpos(); tempscrptr = scriptpos();
scriptaddress++; //Leave a spot for the fail location reservescriptspace(1); //Leave a spot for the fail location
parsecommand(); parsecommand();
setscriptvalue(tempscrptr, scriptpos()); setscriptvalue(tempscrptr, scriptpos());
} }
@ -1304,8 +1269,7 @@ int parsecommand()
do do
{ {
transnum(); transnum();
popscriptvalue(); j |= popscriptvalue();
j |= *scriptaddress;
} while (keyword() == -1); } while (keyword() == -1);
appendscriptvalue(j); appendscriptvalue(j);
goto if_common; goto if_common;
@ -1405,8 +1369,7 @@ int parsecommand()
case concmd_definevolumename: case concmd_definevolumename:
popscriptvalue(); popscriptvalue();
transnum(); transnum();
popscriptvalue(); j = popscriptvalue();
j = *scriptaddress;
while (*textptr == ' ' || *textptr == '\t') textptr++; while (*textptr == ' ' || *textptr == '\t') textptr++;
i = 0; i = 0;
@ -1423,8 +1386,7 @@ int parsecommand()
case concmd_defineskillname: case concmd_defineskillname:
popscriptvalue(); popscriptvalue();
transnum(); transnum();
popscriptvalue(); j = popscriptvalue();
j = *scriptaddress;
while (*textptr == ' ') textptr++; while (*textptr == ' ') textptr++;
i = 0; i = 0;
@ -1442,11 +1404,9 @@ int parsecommand()
case concmd_definelevelname: case concmd_definelevelname:
popscriptvalue(); popscriptvalue();
transnum(); transnum();
popscriptvalue(); j = popscriptvalue();
j = *scriptaddress;
transnum(); transnum();
popscriptvalue(); k = popscriptvalue();
k = *scriptaddress;
while (*textptr == ' ') textptr++; while (*textptr == ' ') textptr++;
i = 0; i = 0;
@ -1490,13 +1450,13 @@ int parsecommand()
case concmd_definequote: case concmd_definequote:
popscriptvalue(); popscriptvalue();
transnum(); transnum();
k = *(scriptaddress - 1); k = popscriptvalue();
if (k >= MAXQUOTES) if (k >= MAXQUOTES)
{ {
Printf(TEXTCOLOR_RED " * ERROR!(%s, line %d) Quote number exceeds limit of %d.\n", line_number, MAXQUOTES); Printf(TEXTCOLOR_RED " * ERROR!(%s, line %d) Quote number exceeds limit of %d.\n", line_number, MAXQUOTES);
errorcount++; errorcount++;
} }
popscriptvalue();
i = 0; i = 0;
while (*textptr == ' ') while (*textptr == ' ')
textptr++; textptr++;
@ -1514,8 +1474,7 @@ int parsecommand()
{ {
popscriptvalue(); popscriptvalue();
transnum(); transnum();
k = *(scriptaddress - 1); k = popscriptvalue();
popscriptvalue();
i = 0; i = 0;
while (*textptr == ' ') while (*textptr == ' ')
textptr++; textptr++;
@ -1529,20 +1488,15 @@ int parsecommand()
parsebuffer.Push(0); parsebuffer.Push(0);
transnum(); transnum();
int ps = *(scriptaddress - 1); int ps = popscriptvalue();
popscriptvalue();
transnum(); transnum();
int pe = *(scriptaddress - 1); int pe = popscriptvalue();
popscriptvalue();
transnum(); transnum();
int pr = *(scriptaddress - 1); int pr = popscriptvalue();
popscriptvalue();
transnum(); transnum();
int m = *(scriptaddress - 1); int m = popscriptvalue();
popscriptvalue();
transnum(); transnum();
int vo = *(scriptaddress - 1); int vo = popscriptvalue();
popscriptvalue();
S_DefineSound(k, parsebuffer.Data(), ps, pe, pr, m, vo, 1.f); S_DefineSound(k, parsebuffer.Data(), ps, pe, pr, m, vo, 1.f);
return 0; return 0;
} }
@ -1625,6 +1579,7 @@ int parsecommand()
return 0; return 0;
case concmd_gamestartup: case concmd_gamestartup:
{ {
popscriptvalue();
auto parseone = []() { transnum(); return popscriptvalue(); }; auto parseone = []() { transnum(); return popscriptvalue(); };
ud.const_visibility = parseone(); ud.const_visibility = parseone();
impact_damage = parseone(); impact_damage = parseone();
@ -1664,7 +1619,6 @@ int parsecommand()
max_ammo_amount[14] = parseone(); max_ammo_amount[14] = parseone();
max_ammo_amount[16] = parseone(); max_ammo_amount[16] = parseone();
} }
scriptaddress++;
} }
return 0; return 0;
} }
@ -1714,7 +1668,7 @@ void loadcons(const char* filenam)
memset(&actorinfo[i], 0, sizeof(actorinfo)); memset(&actorinfo[i], 0, sizeof(actorinfo));
} }
apScript = (intptr_t*)Xcalloc(1, g_scriptSize * sizeof(intptr_t)); ScriptCode.Clear();
labelcnt = 0; labelcnt = 0;
@ -1726,7 +1680,7 @@ void loadcons(const char* filenam)
auto before = I_nsTime(); auto before = I_nsTime();
scriptaddress = apScript + 1; ScriptCode.Push(0);
compilecon(filenam); //Tokenize compilecon(filenam); //Tokenize
if (userConfig.AddCons) for (FString& m : *userConfig.AddCons.get()) if (userConfig.AddCons) for (FString& m : *userConfig.AddCons.get())
@ -1744,7 +1698,7 @@ void loadcons(const char* filenam)
{ {
auto after = I_nsTime(); auto after = I_nsTime();
Printf("Compilation time:%.2f ms, Code Size:%d bytes. %d labels. %d/%d Variables.\n", (after-before) / 1000000., 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, labelcnt,
0,//iGameVarCount, 0,//iGameVarCount,
MAXGAMEVARS MAXGAMEVARS

View file

@ -53,9 +53,6 @@ extern int32_t g_totalLines;
extern int warningcount; extern int warningcount;
extern int32_t otherp; extern int32_t otherp;
extern intptr_t *scriptaddress;
int32_t C_AllocQuote(int32_t qnum); int32_t C_AllocQuote(int32_t qnum);
void C_InitQuotes(void); void C_InitQuotes(void);

View file

@ -80,7 +80,7 @@ void parseifelse(int condition)
} }
else else
{ {
insptr = apScript + *(insptr+1); insptr = &ScriptCode[*(insptr+1)];
if(*insptr == 10) if(*insptr == 10)
{ {
// else... // else...
@ -278,9 +278,9 @@ int parse(void)
case concmd_ai: case concmd_ai:
insptr++; insptr++;
g_t[5] = *insptr; g_t[5] = *insptr;
g_t[4] = apScript[g_t[5]]; // Action g_t[4] = ScriptCode[g_t[5]]; // Action
g_t[1] = apScript[g_t[5] + 1]; // move g_t[1] = ScriptCode[g_t[5] + 1]; // move
g_sp->hitag = apScript[g_t[5] + 2]; // Ai g_sp->hitag = ScriptCode[g_t[5] + 2]; // Ai
g_t[0] = g_t[2] = g_t[3] = 0; g_t[0] = g_t[2] = g_t[3] = 0;
if (g_sp->hitag & random_angle) if (g_sp->hitag & random_angle)
g_sp->ang = krand() & 2047; g_sp->ang = krand() & 2047;
@ -307,7 +307,7 @@ int parse(void)
hittype[g_i].timetosleep = SLEEPTIME; hittype[g_i].timetosleep = SLEEPTIME;
break; break;
case concmd_else: case concmd_else:
insptr = apScript + *(insptr + 1); insptr = &ScriptCode[*(insptr + 1)];
break; break;
case concmd_addstrength: case concmd_addstrength:
insptr++; insptr++;
@ -826,7 +826,7 @@ int parse(void)
case concmd_state: case concmd_state:
{ {
auto tempscrptr = insptr + 2; auto tempscrptr = insptr + 2;
insptr = apScript + *(insptr + 1); insptr = &ScriptCode[*(insptr + 1)];
while (1) if (parse()) break; while (1) if (parse()) break;
insptr = tempscrptr; insptr = tempscrptr;
} }
@ -1517,7 +1517,7 @@ int parse(void)
default: default:
Printf(TEXTCOLOR_RED "Unrecognized PCode of %ld in parse. Killing current sprite.\n",*insptr); 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; killit_flag = 1;
break; 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 g_t = &hittype[g_i].temp_data[0]; // Sprite's 'extra' data
if (actorinfo[g_sp->picnum].scriptaddress == 0) return; 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; killit_flag = 0;
@ -1552,7 +1552,7 @@ void execute(int i,int p,int x)
if (g_t[4]) if (g_t[4])
{ {
// This code was utterly cryptic in the original source. // 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 numframes = ptr[1];
int increment = ptr[3]; int increment = ptr[3];
int delay = ptr[4]; int delay = ptr[4];
@ -1649,7 +1649,7 @@ void OnEvent(int iEventID, int p, int i, int x)
g_sp = &sprite[g_i]; g_sp = &sprite[g_i];
g_t = &hittype[g_i].temp_data[0]; g_t = &hittype[g_i].temp_data[0];
insptr = apScript + apScriptGameEvent[iEventID]; insptr = &ScriptCode[apScriptGameEvent[iEventID]];
killit_flag = 0; killit_flag = 0;
do do

View file

@ -77,6 +77,7 @@ enum
EVENT_MAXEVENT = EVENT_NUMEVENTS - 1 EVENT_MAXEVENT = EVENT_NUMEVENTS - 1
}; };
extern TArray<intptr_t> ScriptCode;
void OnEvent(int id, int pnum = -1, int snum = -1, int dist = -1); void OnEvent(int id, int pnum = -1, int snum = -1, int dist = -1);

View file

@ -201,9 +201,6 @@ G_EXTERN int16_t ambientlotag[64];
G_EXTERN int16_t ambienthitag[64]; G_EXTERN int16_t ambienthitag[64];
G_EXTERN uint32_t g_ambientCnt; G_EXTERN uint32_t g_ambientCnt;
G_EXTERN intptr_t *apScript;
G_EXTERN intptr_t *scriptaddress;
inline int32_t G_HaveActor(int spriteNum) inline int32_t G_HaveActor(int spriteNum)
{ {
return actorinfo[spriteNum].scriptaddress != NULL; return actorinfo[spriteNum].scriptaddress != NULL;
@ -211,7 +208,7 @@ inline int32_t G_HaveActor(int spriteNum)
inline int32_t G_DefaultActorHealth(int spriteNum) // rename! 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;
} }

View file

@ -173,7 +173,7 @@ void A_MoveSector(int spriteNum)
} }
// NOTE: T5 is AC_ACTION_ID // 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. // this is the same crap as in game.c's tspr manipulation. puke.
// XXX: may access tilesizy out-of-bounds by bad user code. // XXX: may access tilesizy out-of-bounds by bad user code.

View file

@ -1321,7 +1321,7 @@ static int32_t G_InitActor(int32_t i, int32_t tilenum, int32_t set_movflag_uncon
{ {
if (actorinfo[tilenum].scriptaddress) if (actorinfo[tilenum].scriptaddress)
{ {
auto sa = &apScript[actorinfo[tilenum].scriptaddress]; auto sa = &ScriptCode[actorinfo[tilenum].scriptaddress];
SH(i) = sa[0]; SH(i) = sa[0];
AC_ACTION_ID(actor[i].t_data) = sa[1]; AC_ACTION_ID(actor[i].t_data) = sa[1];
AC_MOVE_ID(actor[i].t_data) = sa[2]; 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 // Display TILE_APLAYER sprites with action PSTAND when viewed through
// a camera. // a camera.
auto aplayer_scr = apScript + actorinfo[TILE_APLAYER].scriptaddress; auto aplayer_scr = &ScriptCode[actorinfo[TILE_APLAYER].scriptaddress];
// [0]=strength, [1]=actionofs, [2]=moveofs // [0]=strength, [1]=actionofs, [2]=moveofs
scrofs_action = aplayer_scr[1]; scrofs_action = aplayer_scr[1];
@ -5269,8 +5269,8 @@ default_case2:
if ((unsigned)scrofs_action + ACTION_VIEWTYPE >= (unsigned)g_scriptSize) if ((unsigned)scrofs_action + ACTION_VIEWTYPE >= (unsigned)g_scriptSize)
goto skip; goto skip;
int viewtype = apScript[scrofs_action + ACTION_VIEWTYPE]; int viewtype = ScriptCode[scrofs_action + ACTION_VIEWTYPE];
uint16_t const action_flags = apScript[scrofs_action + ACTION_FLAGS]; uint16_t const action_flags = ScriptCode[scrofs_action + ACTION_FLAGS];
int const invertp = viewtype < 0; int const invertp = viewtype < 0;
l = klabs(viewtype); 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. // XXX: t->picnum can be out-of-bounds by bad user code.
if (l > 0) if (l > 0)
@ -6515,7 +6515,6 @@ static void G_Cleanup(void)
#if 0 #if 0
if (labeltype != (int32_t*)&wall[0]) Xfree(labeltype); if (labeltype != (int32_t*)&wall[0]) Xfree(labeltype);
#endif #endif
Xfree(apScript);
} }

View file

@ -1077,7 +1077,7 @@ int32_t sv_loadheader(FileReader &fill, int32_t spot, savehead_t *h)
return -2; 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 #ifndef DEBUGGINGAIDS
if (havedemo) if (havedemo)