- the first command in the parser is done.

This commit is contained in:
Christoph Oelckers 2020-05-12 18:36:34 +02:00
parent 1cedacb7f4
commit 6a6bbbe71a
5 changed files with 9 additions and 89 deletions

View file

@ -339,11 +339,6 @@ static void appendscriptvalue(int value)
script.Push(value); script.Push(value);
} }
static void appendscriptaddress(int* address)
{
addscriptvalue(int(address - script.Data());
}
static void popscriptvalue() static void popscriptvalue()
{ {
script.Pop(); script.Pop();
@ -376,11 +371,6 @@ static void appendscriptvalue(int value)
scriptWriteValue(value); scriptWriteValue(value);
} }
static void addscriptaddress(int* address)
{
assert(0);
}
static void popscriptvalue() static void popscriptvalue()
{ {
scriptptr--; scriptptr--;

View file

@ -64,7 +64,6 @@ void sv_freemem();
// XXX: The 'bitptr' decl really belongs into gamedef.h, but we don't want to // XXX: The 'bitptr' decl really belongs into gamedef.h, but we don't want to
// pull all of it in savegame.c? // pull all of it in savegame.c?
extern char *bitptr;
enum enum
{ {

View file

@ -6524,7 +6524,6 @@ static void G_Cleanup(void)
if (labeltype != (int32_t*)&wall[0]) Xfree(labeltype); if (labeltype != (int32_t*)&wall[0]) Xfree(labeltype);
#endif #endif
Xfree(apScript); Xfree(apScript);
Xfree(bitptr);
// Xfree(MusicPtr); // Xfree(MusicPtr);

View file

@ -130,10 +130,9 @@ char const * VM_GetKeywordForID(int32_t id)
return "<invalid keyword>"; return "<invalid keyword>";
} }
char *bitptr; // pointer to bitmap of which bytecode positions contain pointers #define BITPTR_SET(x)
#define BITPTR_SET(x) (bitptr[(x)>>3] |= (1<<((x)&7))) #define BITPTR_CLEAR(x)
#define BITPTR_CLEAR(x) (bitptr[(x)>>3] &= ~(1<<((x)&7))) #define BITPTR_IS_POINTER(x)
#define BITPTR_IS_POINTER(x) (bitptr[(x)>>3] & (1<<((x) &7)))
hashtable_t h_gamevars = { MAXGAMEVARS >> 1, NULL }; hashtable_t h_gamevars = { MAXGAMEVARS >> 1, NULL };
@ -163,26 +162,19 @@ static int32_t g_skipBranch;
static int32_t C_SetScriptSize(int32_t newsize) static int32_t C_SetScriptSize(int32_t newsize)
{ {
#if 0
intptr_t const oscript = (intptr_t)apScript; intptr_t const oscript = (intptr_t)apScript;
intptr_t *newscript; intptr_t *newscript;
intptr_t i, j; intptr_t i, j;
int32_t osize = g_scriptSize; int32_t osize = g_scriptSize;
char *scriptptrs; char *scriptptrs;
char *newbitptr;
scriptptrs = (char *)Xcalloc(1, g_scriptSize * sizeof(uint8_t)); scriptptrs = (char *)Xcalloc(1, g_scriptSize * sizeof(uint8_t));
for (i = g_scriptSize - 1; i >= 0; i--) for (i = g_scriptSize - 1; i >= 0; i--)
{ {
if (BITPTR_IS_POINTER(i)) if (apScript[i] >= (intptr_t)&apScript[0] && apScript[i] < (intptr_t)&apScript[g_scriptSize])
{ {
if (EDUKE32_PREDICT_FALSE((intptr_t)apScript[i] < (intptr_t)&apScript[0] || (intptr_t)apScript[i] >= (intptr_t)&apScript[g_scriptSize]))
{
g_errorCnt++;
buildprint("Internal compiler error at ", i, " (0x", hex(i), ")\n");
VM_ScriptInfo(&apScript[i], 16);
}
scriptptrs[i] = 1; scriptptrs[i] = 1;
apScript[i] -= (intptr_t)&apScript[0]; apScript[i] -= (intptr_t)&apScript[0];
} }
@ -193,18 +185,12 @@ static int32_t C_SetScriptSize(int32_t newsize)
G_Util_PtrToIdx2(&g_tile[0].loadPtr, MAXTILES, sizeof(tiledata_t), apScript, P2I_FWD_NON0); G_Util_PtrToIdx2(&g_tile[0].loadPtr, MAXTILES, sizeof(tiledata_t), apScript, P2I_FWD_NON0);
newscript = (intptr_t *)Xrealloc(apScript, newsize * sizeof(intptr_t)); newscript = (intptr_t *)Xrealloc(apScript, newsize * sizeof(intptr_t));
newbitptr = (char *)Xcalloc(1,(((newsize+7)>>3)+1) * sizeof(uint8_t));
if (newsize >= osize) if (newsize >= osize)
{ {
Bmemset(&newscript[0]+osize,0,(newsize-osize) * sizeof(uint8_t)); Bmemset(&newscript[0]+osize,0,(newsize-osize) * sizeof(uint8_t));
Bmemcpy(newbitptr,bitptr,sizeof(uint8_t) *((osize+7)>>3));
} }
else
Bmemcpy(newbitptr,bitptr,sizeof(uint8_t) *((newsize+7)>>3));
Xfree(bitptr);
bitptr = newbitptr;
if (apScript != newscript) if (apScript != newscript)
{ {
buildprint("Relocating compiled code from to 0x", hex((intptr_t)apScript), " to 0x", hex((intptr_t)newscript), "\n"); buildprint("Relocating compiled code from to 0x", hex((intptr_t)apScript), " to 0x", hex((intptr_t)newscript), "\n");
@ -228,6 +214,7 @@ static int32_t C_SetScriptSize(int32_t newsize)
G_Util_PtrToIdx2(&g_tile[0].loadPtr, MAXTILES, sizeof(tiledata_t), apScript, P2I_BACK_NON0); G_Util_PtrToIdx2(&g_tile[0].loadPtr, MAXTILES, sizeof(tiledata_t), apScript, P2I_BACK_NON0);
Xfree(scriptptrs); Xfree(scriptptrs);
#endif
return 0; return 0;
} }
@ -968,60 +955,7 @@ static int32_t C_ParseCommand(int32_t loop)
case -2: case -2:
return 1; //End return 1; //End
case concmd_state: case concmd_state:
if (!parsing_actor && parsing_state == 0) parsecommand(g_lastKeyword);
{
C_GetNextLabelName();
scriptptr--;
labelcode[labelcnt] = scriptptr-apScript;
//labeltype[labelcnt] = LABEL_STATE;
parsing_state = 1;
Bsprintf(g_szCurrentBlockName,"%s",label+(labelcnt<<6));
if (getkeyword(label + (labelcnt << 6)) >= 0)
{
g_errorCnt++;
C_ReportError(ERROR_ISAKEYWORD);
continue;
}
labelcnt++;
continue;
}
C_GetNextLabelName();
if (EDUKE32_PREDICT_FALSE((j = findlabel(label+(labelcnt<<6))) < 0))
{
C_ReportError(-1);
Printf("%s:%d: error: state `%s' not found.\n",g_scriptFileName,line_number,label+(labelcnt<<6));
g_errorCnt++;
scriptptr++;
continue;
}
/*
if (EDUKE32_PREDICT_FALSE((labeltype[j] & LABEL_STATE) != LABEL_STATE))
{
char *gl = (char *) C_GetLabelType(labeltype[j]);
C_ReportError(-1);
Printf("%s:%d: warning: expected state, found %s.\n", g_scriptFileName, line_number, gl);
g_warningCnt++;
Xfree(gl);
*(scriptptr-1) = concmd_nullop; // get rid of the state, leaving a nullop to satisfy if conditions
BITPTR_CLEAR(scriptptr-apScript-1);
continue; // valid label name, but wrong type
}
*/
if (!(g_errorCnt || g_warningCnt) && g_scriptDebug > 1)
Printf("%s:%d: debug: state label `%s'.\n", g_scriptFileName, line_number, label+(j<<6));
*scriptptr = (intptr_t) (apScript+labelcode[j]);
// 'state' type labels are always script addresses, as far as I can see
BITPTR_SET(scriptptr-apScript);
scriptptr++;
continue; continue;
case concmd_ends: case concmd_ends:
@ -2500,8 +2434,6 @@ void C_Compile(const char *fileName)
Xfree(apScript); Xfree(apScript);
apScript = (intptr_t *)Xcalloc(1, g_scriptSize * sizeof(intptr_t)); apScript = (intptr_t *)Xcalloc(1, g_scriptSize * sizeof(intptr_t));
bitptr = (char *)Xcalloc(1, (((g_scriptSize + 7) >> 3) + 1) * sizeof(uint8_t));
// Printf("script: %d, bitptr: %d\n",script,bitptr);
labelcnt = 0; labelcnt = 0;
g_defaultLabelCnt = 0; g_defaultLabelCnt = 0;

View file

@ -1264,7 +1264,7 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
else if (tw == concmd_state) else if (tw == concmd_state)
{ {
intptr_t const *const tempscrptr = insptr + 2; intptr_t const *const tempscrptr = insptr + 2;
insptr = (intptr_t *)*(insptr + 1); insptr = apScript + *(insptr + 1);
VM_Execute(1); VM_Execute(1);
insptr = tempscrptr; insptr = tempscrptr;
continue; continue;