mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-19 05:40:48 +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
|
@ -4889,11 +4889,11 @@ void alterang(int a, int g_i, int g_p)
|
||||||
{
|
{
|
||||||
short aang, angdif, goalang, j;
|
short aang, angdif, goalang, j;
|
||||||
int ticselapsed;
|
int ticselapsed;
|
||||||
intptr_t *moveptr;
|
intptr_t* moveptr;
|
||||||
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;
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -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.
|
||||||
|
|
|
@ -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);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in a new issue